Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/signalsciences/rsrc

Utility components for managing fetch operations in React
https://github.com/signalsciences/rsrc

frontend

Last synced: 2 months ago
JSON representation

Utility components for managing fetch operations in React

Awesome Lists containing this project

README

        

![Logo](https://signalsciences.github.io/rsrc/static/rsrc-logo.svg)

![Rsrc](https://signalsciences.github.io/rsrc/static/rsrc-type.svg)

[![ci][ci-badge]][ci]
[![version][version-badge]][npm]
[![license][license-badge]](LICENSE.md)
[![gzip size][gzip-badge]][gzip]

[ci-badge]: https://github.com/signalsciences/rsrc/workflows/CI/badge.svg
[ci]: https://github.com/signalsciences/rsrc/actions
[version-badge]: https://badgen.net/npm/v/rsrc
[npm]: https://npmjs.com/package/rsrc
[gzip-badge]: http://badgen.net/bundlephobia/minzip/rsrc
[gzip]: https://bundlephobia.com/result?p=rsrc
[license-badge]: https://badgen.net/badge/license/MIT/blue

A collection of components designed to simplify fetch state in React.

**[Docs](https://signalsciences.github.io/rsrc)**

## Getting Started

```
yarn add rsrc
```

## Usage

```jsx
import React from "react";
import { Resource } from "rsrc";

export default (props) => {
const { id } = props;
const url = `/todos/${id}`;

return (
({
options: {
method: "DELETE",
},
invalidates: ["/todos"],
}),
}}
>
{({ state, actions }) => {
if (!state.fulfilled) return null;

const todo = state.value;

const handleClick = () => {
actions
.remove()
.then((value) => {
/* */
})
.catch((error) => {
/* */
});
};

return (


{todo.name}


{todo.description}


×

);
}}

);
};
```

### Related

- [Redux](https://github.com/reduxjs/redux)
- [React Refetch](https://github.com/heroku/react-refetch)