Home

Awesome

rescript-urql

npm All Contributors Build Status ![Maintenance Status][maintenance-image]

ReScript bindings for Formidable's Universal React Query Library, urql.

πŸ“£ Please note these bindings were previously maintained by Formidable, but have since been taken over by the ReScript Brazil community.

✨Features

rescript-urql is a GraphQL client for rescript-react, allowing you to hook up your components to queries, mutations, and subscriptions. It provides bindings to urql that allow you to use the API in ReScript, with the benefits of a sound type system, blazing fast compilation, and opportunities for guided customization.

πŸ“‹ Documentation

πŸ’Ύ Installation

1. Install @urql/rescript alongside its peerDependencies and devDependencies.

yarn add @urql/rescript urql graphql
yarn add gentype --dev

We try to keep our bindings as close to latest urql as possible. However, urql tends to make releases a bit ahead of rescript-urql. To get a compatible version, we recommend always staying strictly within this project's peerDependency range for urql.

The gentype devDependency is a requirement introduced by urql's use of wonka. wonka's source uses @genType declarations, so when the BuckleScript / ReScript compiler attempts to compile wonka in your project, it'll need a local copy of gentype to use.

1a. Important note for users of bs-platform>=8.0.0.

If using bs-platform>=8.0.0 you'll need to use yarn resolutions to specify a specific version of wonka to resolve. urql has an explicit dependency on latest wonka v4, which is incompatible with bs-platform>=8.0.0. See this issue for more details.

In your package.json, add the following:

"resolutions": {
  "wonka": "5.0.0-rc.1"
}

If you're using npm, you may need to stay on bs-platform@7.3.2 until urql takes a dependency on wonka>=5.0.0.

2. Add @reasonml-community/graphql-ppx.

To get the most out of compile time type checks for your GraphQL queries, mutations, and subscriptions, we use @reasonml-community/graphql-ppx. Add this to your project's devDependencies.

yarn add @reasonml-community/graphql-ppx --dev

3. Update bsconfig.json.

Add @urql/rescript, wonka, and @reasonml-community/graphql-ppx to your bs-dependencies and @reasonml-community/graphql-ppx/ppx to your ppx_flags in bsconfig.json.

{
  "bs-dependencies": [
    "@urql/rescript",
    "wonka",
    "@reasonml-community/graphql-ppx"
  ],
  "ppx-flags": ["@reasonml-community/graphql-ppx/ppx"]
}

4. Send an introspection query to your API.

Finally, you'll need to send an introspection query to your GraphQl API, using a tool like graphql-cli. You should generate a file called graphql_schema.json at the root of your project that graphql-ppx can use to type check your queries. You should check this file into version control and keep it updated as your API changes.

For additional help, head here.

npx get-graphql-schema ENDPOINT_URL -j > graphql_schema.json

Simply re-run this script at anytime to regenerate the graphql_schema.json file according to your latest backend schema.

πŸ’» Example Projects

rescript-urql has a nice set of examples showing how to use the hooks and client APIs to get the most out of GraphQL and ReScript in your app – check them out in the /examples folder. To run any of the examples, follow these steps.

# 1. Navigate into the example of choice.
cd examples/1-execute-query-mutation

# 2. Install dependencies.
yarn

# 3. In one terminal, compile the source in watch mode.
yarn start

# 4. In another terminal, start the demo app server.
yarn start:demo

The example will start up at http://localhost:3000. Edit the example freely to watch changes take effect.

Editing rescript-urql source files

If developing on the main rescript-urql source files (i.e. anything in /src/) and you want to test the changes in one of the examples, you'll need to do the following:

# Save your changes to source, then take the following steps.

# 1. Clean any artifacts from previous builds.
yarn clean

# 2. Rebuild the source.
yarn build

# 3. Clean example build and reinstall dependencies.
cd examples/2-query
yarn clean
yarn

Since we are linking the examples' dependency on rescript-urql to the src directory, it's important to clean builds between changes to prevent any stale or erroneous artifacts.

Getting Involved

Please help out by opening an issue or filing a PR.

Contributors

This project follows the all contributors spec. Thanks to these wonderful folks for contributing (Emoji Key):

<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section --> <!-- prettier-ignore-start --> <!-- markdownlint-disable --> <table> <tr> <td align="center"><a href="http://parkerziegler.com/"><img src="https://avatars0.githubusercontent.com/u/19421190?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Parker Ziegler</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=parkerziegler" title="Code">πŸ’»</a> <a href="https://github.com/FormidableLabs/rescript-urql/commits?author=parkerziegler" title="Documentation">πŸ“–</a> <a href="https://github.com/FormidableLabs/rescript-urql/pulls?q=is%3Apr+reviewed-by%3Aparkerziegler" title="Reviewed Pull Requests">πŸ‘€</a> <a href="#ideas-parkerziegler" title="Ideas, Planning, & Feedback">πŸ€”</a></td> <td align="center"><a href="https://khoanguyen.me"><img src="https://avatars2.githubusercontent.com/u/3049054?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Khoa Nguyen</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=thangngoc89" title="Code">πŸ’»</a> <a href="https://github.com/FormidableLabs/rescript-urql/commits?author=thangngoc89" title="Documentation">πŸ“–</a></td> <td align="center"><a href="https://twitter.com/_philpl"><img src="https://avatars0.githubusercontent.com/u/2041385?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Phil PlΓΌckthun</b></sub></a><br /><a href="#ideas-kitten" title="Ideas, Planning, & Feedback">πŸ€”</a></td> <td align="center"><a href="https://github.com/kiraarghy"><img src="https://avatars2.githubusercontent.com/u/21056165?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Kara Stubbs</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=kiraarghy" title="Code">πŸ’»</a> <a href="https://github.com/FormidableLabs/rescript-urql/commits?author=kiraarghy" title="Tests">⚠️</a> <a href="#example-kiraarghy" title="Examples">πŸ’‘</a></td> <td align="center"><a href="https://github.com/oddlyfunctional"><img src="https://avatars1.githubusercontent.com/u/565635?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Marcos Felipe Pimenta Rodrigues</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=oddlyfunctional" title="Documentation">πŸ“–</a></td> <td align="center"><a href="https://github.com/gugahoa"><img src="https://avatars2.githubusercontent.com/u/1438470?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Gustavo Aguiar</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=gugahoa" title="Code">πŸ’»</a> <a href="#example-gugahoa" title="Examples">πŸ’‘</a></td> </tr> <tr> <td align="center"><a href="https://github.com/Schmavery"><img src="https://avatars1.githubusercontent.com/u/2154522?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Avery Morin</b></sub></a><br /><a href="#ideas-Schmavery" title="Ideas, Planning, & Feedback">πŸ€”</a> <a href="https://github.com/FormidableLabs/rescript-urql/commits?author=Schmavery" title="Code">πŸ’»</a> <a href="#example-Schmavery" title="Examples">πŸ’‘</a> <a href="https://github.com/FormidableLabs/rescript-urql/commits?author=Schmavery" title="Documentation">πŸ“–</a></td> <td align="center"><a href="https://medium.com/@idkjs"><img src="https://avatars1.githubusercontent.com/u/2370391?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Alain Armand</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=idkjs" title="Code">πŸ’»</a> <a href="#example-idkjs" title="Examples">πŸ’‘</a></td> <td align="center"><a href="http://weser.io"><img src="https://avatars0.githubusercontent.com/u/10060928?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Robin Weser</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=robinweser" title="Documentation">πŸ“–</a></td> <td align="center"><a href="https://ce.ms"><img src="https://avatars3.githubusercontent.com/u/959142?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Cem Turan</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=cem2ran" title="Documentation">πŸ“–</a></td> <td align="center"><a href="https://www.huy.dev/"><img src="https://avatars1.githubusercontent.com/u/7352279?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Huy Nguyen</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=huy-nguyen" title="Documentation">πŸ“–</a></td> <td align="center"><a href="http://www.riseos.com"><img src="https://avatars2.githubusercontent.com/u/35296?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Sean Grove</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=sgrove" title="Code">πŸ’»</a> <a href="#example-sgrove" title="Examples">πŸ’‘</a> <a href="#ideas-sgrove" title="Ideas, Planning, & Feedback">πŸ€”</a> <a href="https://github.com/FormidableLabs/rescript-urql/commits?author=sgrove" title="Documentation">πŸ“–</a></td> </tr> <tr> <td align="center"><a href="https://twitter.com/_cichocinski"><img src="https://avatars2.githubusercontent.com/u/9558691?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Tomasz Cichocinski</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=baransu" title="Code">πŸ’»</a> <a href="https://github.com/FormidableLabs/rescript-urql/issues?q=author%3Abaransu" title="Bug reports">πŸ›</a></td> <td align="center"><a href="https://www.jovidecroock.com/"><img src="https://avatars3.githubusercontent.com/u/17125876?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Jovi De Croock</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=JoviDeCroock" title="Code">πŸ’»</a></td> <td align="center"><a href="https://github.com/tatchi"><img src="https://avatars2.githubusercontent.com/u/5595092?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Corentin Leruth</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=tatchi" title="Documentation">πŸ“–</a> <a href="https://github.com/FormidableLabs/rescript-urql/commits?author=tatchi" title="Code">πŸ’»</a></td> <td align="center"><a href="https://github.com/jeddeloh"><img src="https://avatars3.githubusercontent.com/u/1131723?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Joel Jeddeloh</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=jeddeloh" title="Code">πŸ’»</a></td> <td align="center"><a href="https://github.com/hulufei"><img src="https://avatars0.githubusercontent.com/u/261677?v=4?s=100" width="100px;" alt=""/><br /><sub><b>hui.liu</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=hulufei" title="Documentation">πŸ“–</a></td> <td align="center"><a href="https://github.com/gaku-sei"><img src="https://avatars0.githubusercontent.com/u/3982371?v=4?s=100" width="100px;" alt=""/><br /><sub><b>KΓ©vin Combriat</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=gaku-sei" title="Code">πŸ’»</a> <a href="https://github.com/FormidableLabs/rescript-urql/issues?q=author%3Agaku-sei" title="Bug reports">πŸ›</a> <a href="#ideas-gaku-sei" title="Ideas, Planning, & Feedback">πŸ€”</a></td> </tr> <tr> <td align="center"><a href="http://amiralies.github.io"><img src="https://avatars3.githubusercontent.com/u/13261088?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Amirali Esmaeili</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=amiralies" title="Code">πŸ’»</a> <a href="#example-amiralies" title="Examples">πŸ’‘</a></td> <td align="center"><a href="https://www.alexandervarwijk.com"><img src="https://avatars1.githubusercontent.com/u/327697?v=4?s=100" width="100px;" alt=""/><br /><sub><b>Alexander Varwijk</b></sub></a><br /><a href="https://github.com/FormidableLabs/rescript-urql/commits?author=Kingdutch" title="Code">πŸ’»</a></td> </tr> </table> <!-- markdownlint-restore --> <!-- prettier-ignore-end --> <!-- ALL-CONTRIBUTORS-LIST:END -->