2020-09-02 10:40:47 -07:00
|
|
|
|
2020-09-02 11:08:06 -07:00
|
|
|
// makeFetcher - replacement for setInterval for fetching, starts counting
|
|
|
|
// the interval only after a request is done instead of immediately.
|
|
|
|
// promiseCall is a function that returns a promise, it's called when created
|
|
|
|
// and after every interval.
|
|
|
|
// interval is the interval delay in ms.
|
|
|
|
|
|
|
|
export const makeFetcher = (promiseCall, interval) => {
|
2020-09-02 10:40:47 -07:00
|
|
|
let stopped = false
|
|
|
|
let timeout = null
|
|
|
|
let func = () => {}
|
|
|
|
|
|
|
|
func = () => {
|
2020-09-02 11:08:06 -07:00
|
|
|
promiseCall().finally(() => {
|
2020-09-02 10:40:47 -07:00
|
|
|
if (stopped) return
|
|
|
|
timeout = window.setTimeout(func, interval)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
const stopFetcher = () => {
|
|
|
|
stopped = true
|
2020-09-02 11:01:31 -07:00
|
|
|
window.clearTimeout(timeout)
|
2020-09-02 10:40:47 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
func()
|
|
|
|
|
|
|
|
return stopFetcher
|
|
|
|
}
|