Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/xcarpentier/react-redux-dispatch-async

🎸 react-redux hook & redux middleware to be able to wait for async actions with fixed defined suffixes
https://github.com/xcarpentier/react-redux-dispatch-async

async async-actions react react-hooks redux

Last synced: 20 days ago
JSON representation

🎸 react-redux hook & redux middleware to be able to wait for async actions with fixed defined suffixes

Awesome Lists containing this project

README

        



npm version

npm downloads



# react-redux-dispatch-async

👉 REDUX _middleware_ & **HOOK** 🎉 waiting async _actions_ with **SUFFIXES** 👈

```tsx
import { useDispatchAsync } from 'react-redux-dispatch-async'

export default function MyUserInterface({ id }: { id: string }) {
// 👉 pass action and arguments into the array
const response = useDispatchAsync(getUserActionRequest, [id])

switch (response.status) {
case 'loading':
return
case 'error':
return {response.error.message}
case 'success':
return
case 'timeout':
return {'timeout ¯\\_(ツ)_//¯'}
case 'canceled':
return {'canceled ¯\\_(ツ)_//¯'}
default:
return null
}
}
```

If you need more examples you can go to [github](https://github.com/xcarpentier/react-redux-dispatch-async-example) or to [codesandbox](https://codesandbox.io/s/react-redux-dispatch-async-rij31?file=/src/UserContainer.tsx).

## Install

`yarn add react-redux-dispatch-async`

## Features
```

+------------------+
| ACTION_REQUESTED |----+
+------------------+ | +------------------+
+----->| ACTION_SUCCEEDED |
| +------------------+
|
| +--------------------+
+----->| ACTION_FAILED |
| +--------------------+
|
| +--------------------+
+----->| ACTION_CANCELED |
+--------------------+
```

### Race condition to execute only the promise if multiple update occur in nearly same time

[> Dig into it](https://github.com/xcarpentier/react-redux-dispatch-async/blob/master/src/useDispatchAsync.ts#L65)

### Hook give you helpful STATUS you can deal with into your own component

- ⏳ **`loading`**: action start but not yet completed
- 👏 **`success`**: action completed, you can get the result
- 😱 **`error`**: action failed and you can get the error
- 👎 **`timeout`**: action not completed for too long (ie. options?.timeoutInMilliseconds)
- 👋 **`canceled`**: action canceled
- 😮 **`unknown`**: should never happen

### Configuration

```ts
import { createStore, applyMiddleware } from 'redux'
import { createDispatchAsyncMiddleware } from 'react-redux-dispatch-async'
import reducers from 'reducers'

const store = createStore(
reducers,
applyMiddleware(
createDispatchAsyncMiddleware({
request: 'REQUEST', // 👈 define your own async suffixes
success: 'SUCCESS',
failure: 'FAILURE',
cancel: 'CANCEL', // optional
}),
),
)
```

## Default suffixes

- `[...]_REQUESTED`
- `[...]_SUCCEEDED`
- `[...]_FAILED`
- `[...]_CANCELED`

## Two functions

### Configuration

```ts
dispatchAsyncMiddleware: (c?: {
request: string
success: string
failure: string
cancel?: string
}) => redux.Middleware
```

### Type

```ts
// main hook
interface Options {
timeoutInMilliseconds?: number
}
type useDispatchAsync = (
actionFunction?: (...args: any[]) => Action,
deps: any[] = [],
options: Options = { timeoutInMilliseconds: 15000 }, // wait 15s
) => UseDispatchAsync

/// return type
interface ResultLoading {
status: 'loading'
}

interface ResultSuccess {
status: 'success'
result: R
}

interface ResultError {
status: 'error'
error: Error
}

interface ResultCancel {
status: 'canceled'
}

interface ResultTimeout {
status: 'timeout'
}

interface ResultUnknown {
status: 'unknown'
}

export type UseDispatchAsync =
| ResultLoading
| ResultSuccess
| ResultError
| ResultTimeout
| ResultCancel
| ResultUnknown

// other types for oldest usage
interface DispatchAsyncResultSuccess {
success: true
result: T
}
interface DispatchAsyncResultError {
success: false
error: Error
}
export type DispatchAsyncResult =
| DispatchAsyncResultSuccess
| DispatchAsyncResultError
```

## Hire an expert!

Looking for a ReactNative freelance expert with more than 14 years experience? Contact me from my [website](https://xaviercarpentier.com)!