UNPKG

redux-persist

Version:

persist and rehydrate redux stores

57 lines (48 loc) 1.36 kB
// @flow import React, { PureComponent } from 'react' // eslint-disable-line import/no-unresolved import type { Node } from 'react' // eslint-disable-line import/no-unresolved import type { Persistor } from '../types' type Props = { onBeforeLift?: Function, children?: Node, loading?: Node, persistor: Persistor, } type State = { bootstrapped: boolean, } export class PersistGate extends PureComponent<Props, State> { static defaultProps = { loading: null, } state = { bootstrapped: false, } _unsubscribe: ?Function componentDidMount() { this._unsubscribe = this.props.persistor.subscribe( this.handlePersistorState ) this.handlePersistorState() } handlePersistorState = () => { const { persistor } = this.props let { bootstrapped } = persistor.getState() if (bootstrapped) { if (this.props.onBeforeLift) { Promise.resolve(this.props.onBeforeLift()) .then(() => this.setState({ bootstrapped: true })) .catch(() => this.setState({ bootstrapped: true })) } else { this.setState({ bootstrapped: true }) } this._unsubscribe && this._unsubscribe() } } componentWillUnmount() { this._unsubscribe && this._unsubscribe() } render() { return this.state.bootstrapped ? this.props.children : this.props.loading } }