sanity
Version:
Sanity is a real-time content infrastructure with a scalable, hosted backend featuring a Graph Oriented Query Language (GROQ), asset pipelines and fast edge caches
31 lines (25 loc) • 995 B
text/typescript
import {useMemoObservable} from 'react-rx'
import {of, timer} from 'rxjs'
import {distinctUntilChanged, map, mapTo, startWith, switchMap} from 'rxjs/operators'
import {useDocumentStore} from '../store'
/** @internal */
export type ConnectionState = 'connecting' | 'reconnecting' | 'connected'
const INITIAL: ConnectionState = 'connecting'
/** @internal */
export function useConnectionState(publishedDocId: string, docTypeName: string): ConnectionState {
const documentStore = useDocumentStore()
return useMemoObservable(
() =>
documentStore.pair.documentEvents(publishedDocId, docTypeName).pipe(
map((ev: {type: string}) => ev.type),
map((eventType) => eventType !== 'reconnect'),
switchMap((isConnected) =>
isConnected ? of('connected') : timer(200).pipe(mapTo('reconnecting')),
),
startWith(INITIAL as any),
distinctUntilChanged(),
),
[documentStore.pair, publishedDocId, docTypeName],
INITIAL,
)
}