Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/capaj/react-promise
a react.js hook for general promise in typescript
https://github.com/capaj/react-promise
asynchronous hacktoberfest react-component reactjs
Last synced: 2 months ago
JSON representation
a react.js hook for general promise in typescript
- Host: GitHub
- URL: https://github.com/capaj/react-promise
- Owner: capaj
- License: mit
- Created: 2015-12-25T23:08:28.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2022-12-09T00:45:43.000Z (about 2 years ago)
- Last Synced: 2024-04-10T20:22:40.493Z (9 months ago)
- Topics: asynchronous, hacktoberfest, react-component, reactjs
- Language: TypeScript
- Homepage:
- Size: 1.33 MB
- Stars: 93
- Watchers: 4
- Forks: 19
- Open Issues: 21
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- stars - capaj/react-promise
README
# react-promise
[![NPM badge](https://nodei.co/npm/react-promise.png?downloads=true&downloadRank=true&stars=true)](https://nodei.co/npm/react-promise/)
a react.js hook for general promise written in typescript.
Let's consider a trivial example: you have a promise such as this```javascript
let prom = new Promise(function(resolve, reject) {
setTimeout(function() {
resolve('a value')
}, 100)
})
```and you want to make a component, which renders out in it's body 'a value'. Without react-promise, such component may look like this:
```javascript
class ExampleWithoutAsync extends React.Component { // you can't use stateless component because you need a state
constructor () {
super()
this.state = {}
}
componentDidMount() {
prom.then((value) => {
this.setState({val: value})
})
}
render () {
if (!this.state.val) return null
return{this.state.val}
}// or you could use a combination of useEffect and useState hook, which is basically the implementation of this small library
```and with react-promise:
```tsx
import usePromise from 'react-promise';const ExampleWithAsync = (props) => {
const {value, loading} = usePromise(prom)
if (loading) return null
return{value}}
}
```## API
The only argument can be a promise or a promise resolving thunk:
```ts
usePromise(
promiseOrFn: (() => Promise) | Promise
)
```it might be desirable to let the usePromise call the promise returnig function, because you often don't want to do that inside the render of your functional component.
Full state object interface returned by the hook looks like:
```ts
{
loading: boolean
error: Error | null
value: T | undefined // where T is your shape of the resolved data you expect obviously
}
```## install
With npm:
```
npm i react-promise
```[For version 2 docs, refer to the old readme](https://github.com/capaj/react-promise/tree/1691b7202be806db5f41784d6e2cc9d231a3975c#react-promise).