Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ivanross/react-promise-manager
Yet another Promise utility library for React.
https://github.com/ivanross/react-promise-manager
hook promise react
Last synced: 3 months ago
JSON representation
Yet another Promise utility library for React.
- Host: GitHub
- URL: https://github.com/ivanross/react-promise-manager
- Owner: ivanross
- License: mit
- Created: 2020-12-20T11:20:36.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2023-11-21T18:17:57.000Z (about 1 year ago)
- Last Synced: 2024-04-24T13:36:27.297Z (9 months ago)
- Topics: hook, promise, react
- Language: TypeScript
- Homepage:
- Size: 591 KB
- Stars: 6
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# React Promise Manager
Yet another Promise utility library for React.
- [Getting Started](#getting-started)
- [`usePromise`](#usepromise)
- [`ManagedPromise`](#managedpromise)
- [Accessing PromiseState via function](#accessing-promisestate-via-function)
- [Accessing PromiseState via hook](#accessing-promisestate-via-hook)## Getting Started
```
npm install react react-promise-manager
```## `usePromise`
Accepts `Promise | () => Promise` and an array of dependency. Returns PromiseState.
```jsx
import { usePromise } from 'react-promise-manager'const App = () => {
const promiseState = usePromise(fetchMyData, [])if (promiseState.state === 'pending') return 'loading... ⏱'
if (promiseState.state === 'rejected') {
return `Oops, something went wrong 😞: ${promiseState.error}`
}const { result } = promiseState
return (
Here's my data! 🎉
{JSON.stringify(promiseResult)}
)
}
```## `ManagedPromise`
Pass a `Promise | () => Promise` to `ManagedPromise` and with `Resolved`, `Rejected` and `Pending` you can choose what to render accordingly to the promise state.
```jsx
import { ManagedPromise, Pending, Rejected, Resolved } from 'react-promise-manager'const App = () => (
loading... ⏱
Oops, something went wrong 😞
)
```### Accessing PromiseState via function
To access the result or the error returned by the promise, a function can be passed to `Resolved` and `Rejected` as child:
```jsx
const App = () => (
{result => }
{error => }
)
```The same thing can be done with `ManagedPromise` to access PromiseState:
```jsx
const App = () => (
{promiseState => ... }
)
```### Accessing PromiseState via hook
Alternatively, the result or error of the promise can be accessed with `usePromiseResult` and `usePromiseError`:
```jsx
const MyComponent = () => {
const result = usePromiseResult()
...
}const MyErrorHandler = () => {
const result = usePromiseError()
...
}const App = () => (
)
```Full PromiseState can be accesed with `usePromiseState`:
```jsx
const MyComponent = () => {
const promiseState = usePromiseState()
...
}const App = () => (
)
```- `usePromiseState` can be used only in a `ManagedPromise` child
- `usePromiseResult` can be used only in a `Resolved` child
- `usePromiseError` can be used only in a `Rejected` child