2018-01-17 16:39:26 +00:00
|
|
|
// Thank you, github.com/ryanseddon/redux-debounced
|
|
|
|
|
|
|
|
export default () => {
|
|
|
|
let timers = {}
|
|
|
|
|
|
|
|
let time = 500
|
|
|
|
|
|
|
|
let middleware = () => dispatch => action => {
|
|
|
|
let { type } = action
|
|
|
|
|
|
|
|
let key = type
|
|
|
|
|
2018-01-30 16:11:33 +00:00
|
|
|
let shouldDebounce = key === '@@redux-form/CHANGE'
|
2018-01-17 16:39:26 +00:00
|
|
|
|
2018-01-30 16:11:33 +00:00
|
|
|
if (key === '@@redux-form/UPDATE_SYNC_ERRORS') {
|
|
|
|
dispatch(action)
|
|
|
|
return clearTimeout(timers['@@redux-form/CHANGE'])
|
2018-01-17 16:39:26 +00:00
|
|
|
}
|
|
|
|
|
2018-01-30 16:11:33 +00:00
|
|
|
if (!shouldDebounce) return dispatch(action)
|
|
|
|
|
2018-01-17 16:39:26 +00:00
|
|
|
if (timers[key]) {
|
|
|
|
clearTimeout(timers[key])
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(action)
|
|
|
|
return new Promise(resolve => {
|
|
|
|
timers[key] = setTimeout(() => {
|
|
|
|
resolve(dispatch({ type: 'USER_INPUT_UPDATE' }))
|
|
|
|
}, time)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
middleware._timers = timers
|
|
|
|
|
|
|
|
return middleware
|
|
|
|
}
|