-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathvalidateAction.ts
More file actions
35 lines (31 loc) · 1.35 KB
/
validateAction.ts
File metadata and controls
35 lines (31 loc) · 1.35 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
// thunk: (dispatch, getState, extra) => unknown
const isPromiseLike = (thing: any): thing is PromiseLike<unknown> => thing && typeof thing === "object" && typeof thing.then === "function"
type Action = { type: string;[key: string]: any }
type Validate = {
<AC extends (...args: any[]) => Action>(actionCreator: AC, validator: (getState: () => any, ...actionArgs: Parameters<AC>) => Promise<unknown>):
(...args: Parameters<AC>) =>
(dispatch, getState) =>
Promise<boolean>
<AC extends (...args: any[]) => Action>(actionCreator: AC, validator: (getState: () => any, ...actionArgs: Parameters<AC>) => unknown):
(...args: Parameters<AC>) =>
(dispatch, getState) =>
boolean
}
export const validate: Validate = ((actionCreator, validator) => (...args) => (dispatch, getState) => {
try {
const validationResult = validator(getState, ...args)
if (isPromiseLike(validationResult)) {
const promise = Promise.resolve(validationResult)
return promise
.then(res => res ? (dispatch(actionCreator(...args)), true) : false)
.catch(() => false)
} else if (validationResult) {
dispatch(actionCreator(...args))
return true
} else {
return false
}
} catch (e) {
return false
}
}) as any