You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

35 lines
955 B

import React from 'react'
import PropTypes from 'prop-types'
import { withTheme } from 'styled-components'
import LoadingBolt from 'components/LoadingBolt'
const LoadingBoltWithTheme = withTheme(LoadingBolt)
/**
* A HOC that will display the LoadingBolt component whilast the wrapped component is loading.
* @param {React.Component} Component Component to wrap
*/
const withLoading = Component =>
class extends React.Component {
static displayName = 'withLoading'
static propTypes = {
isLoading: PropTypes.bool.isRequired
}
/**
* Render the loading bolt ontop of the wrapped component for as long as needed.
*/
render() {
const { isLoading, theme, children, ...rest } = this.props
return (
<React.Fragment>
<LoadingBoltWithTheme isLoading={isLoading} />
<Component {...rest}>{children}</Component>
</React.Fragment>
)
}
}
export default withLoading