Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/awmleer/use-async-memo

React hook for generating async memoized data.
https://github.com/awmleer/use-async-memo

async hook react use-memo

Last synced: 18 days ago
JSON representation

React hook for generating async memoized data.

Awesome Lists containing this project

README

        

# useAsyncMemo

React hook for generating async memoized data.

## API

```typescript
function useAsyncMemo(factory: () => Promise, deps: DependencyList, initial?: T): T
```

If `factory` returns `undefined` or `null`, `useAsyncMemo` will leave the memoized value **unchanged**.

## Demo

### Import

```js
import {useAsyncMemo} from "use-async-memo"
```

### Fetch API:

```js
const data = useAsyncMemo(doAPIRequest, [])
```

or

```js
const data = useAsyncMemo(() => doAPIRequest(), [])
```

or

```js
const data = useAsyncMemo(() => {
return doAPIRequest()
}, [])
```

or

```js
const data = useAsyncMemo(async () => {
return await doAPIRequest()
}, [])
```

### Search on inputting:

```js
const [input, setInput] = useState()
const users = useAsyncMemo(async () => {
if (input === '') return []
return await apiService.searchUsers(input)
}, [input], [])
```

### Get loading status:

```js
const [loading, setLoading] = useState(true)
const data = useAsyncMemo(async () => {
setLoading(true)
const response = await doAPIRequest()
setLoading(false)
return response
}, [])
```

### With ability of manual clearing:

```js
const [input, setInput] = useState()

const [clearFlag, setClearFlag] = useState({
val: false
})
function clearItems() {
setClearFlag({
val: true
})
}

const users = useAsyncMemo(async () => {
if (clearFlag.val) {
clearFlag.val = false
return null
}
if (input === '') return []
return await apiService.searchUsers(input)
}, [input, clearFlag], [])
```

### With debounced value:

> see [use-debounce](https://github.com/xnimorz/use-debounce)

```js
const [input, setInput] = useState()
const [debouncedInput] = useDebounce(input, 300)
const users = useAsyncMemo(async () => {
if (debouncedInput === '') return []
return await apiService.searchUsers(debouncedInput)
}, [debouncedInput], [])
```