All files / src/fetch index.js

100% Statements 10/10
100% Branches 0/0
100% Functions 6/6
100% Lines 10/10
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44                                          15x 15x 15x       13x 13x       28x 22x 5x       55x 55x        
/* Copyright © 2016 Kuali, Inc. - All Rights Reserved
 * You may use and modify this code under the terms of the Kuali, Inc.
 * Pre-Release License Agreement. You may not distribute it.
 *
 * You should have received a copy of the Kuali, Inc. Pre-Release License
 * Agreement with this file. If not, please write to license@kuali.co.
 */
 
import PropTypes from 'prop-types'
import { Component } from 'react'
 
export default class Fetch extends Component {
 
  static displayName = 'Fetch';
 
  static propTypes = {
    children: PropTypes.func.isRequired,
    loadFn: PropTypes.func.isRequired,
  };
 
  constructor(props) {
    super(props)
    this.state = { loading: true, error: null, value: null }
    this.load(this.props)
  }
 
  componentWillReceiveProps(nextProps) {
    this.setState({ loading: true, error: null, value: null })
    this.load(nextProps)
  }
 
  load(props) {
    props.loadFn()
      .then((value) => this.setState({ loading: false, value }))
      .catch((error) => this.setState({ loading: false, error }))
  }
 
  render() {
    const { loading, error, value } = this.state
    return this.props.children(loading, error, value)
  }
 
}