Don't kick to login screen on network error (#4911)
* Don't kick the user on network errors * Track online status for RQ * Use health endpoint * Update test with new behavior * Only poll while offline * Handle races between the check and network events * Reduce the poll kickoff interval * Don't cache partially fetched pinned feeds This isn't a new issue but it's more prominent with the offline handling. We're currently silently caching pinned infos that failed to fetch. This avoids showing a big spinner on failure but it also kills all feeds which is very confusing. If the request to get feed gens fails, let's fail the whole query. Then it can be retried.
This commit is contained in:
parent
7e11b862e9
commit
57be2ea15b
6 changed files with 117 additions and 14 deletions
|
@ -22,6 +22,22 @@ export function listenSessionDropped(fn: () => void): UnlistenFn {
|
|||
return () => emitter.off('session-dropped', fn)
|
||||
}
|
||||
|
||||
export function emitNetworkConfirmed() {
|
||||
emitter.emit('network-confirmed')
|
||||
}
|
||||
export function listenNetworkConfirmed(fn: () => void): UnlistenFn {
|
||||
emitter.on('network-confirmed', fn)
|
||||
return () => emitter.off('network-confirmed', fn)
|
||||
}
|
||||
|
||||
export function emitNetworkLost() {
|
||||
emitter.emit('network-lost')
|
||||
}
|
||||
export function listenNetworkLost(fn: () => void): UnlistenFn {
|
||||
emitter.on('network-lost', fn)
|
||||
return () => emitter.off('network-lost', fn)
|
||||
}
|
||||
|
||||
export function emitPostCreated() {
|
||||
emitter.emit('post-created')
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue