import _ from 'lodash'; import PropTypes from 'prop-types'; import React, { Component } from 'react'; import LazyLoad from 'react-lazyload'; const logoPlaceholder = ''; function findLogo(images) { return _.find(images, { coverType: 'logo' }); } function getLogoUrl(logo, size) { if (logo) { // Remove protocol let url = logo.url.replace(/^https?:/, ''); url = url.replace('logo.jpg', `logo-${size}.jpg`); return url; } } class ArtistLogo extends Component { // // Lifecycle constructor(props, context) { super(props, context); const pixelRatio = Math.floor(window.devicePixelRatio); const { images, size } = props; const logo = findLogo(images); this.state = { pixelRatio, logo, logoUrl: getLogoUrl(logo, pixelRatio * size), hasError: false, isLoaded: false }; } componentDidUpdate(prevProps) { const { images, size } = this.props; const { pixelRatio } = this.state; const logo = findLogo(images); if (logo && logo.url !== this.state.logo.url) { this.setState({ logo, logoUrl: getLogoUrl(logo, pixelRatio * size), hasError: false, isLoaded: false }); } } // // Listeners onError = () => { this.setState({ hasError: true }); } onLoad = () => { this.setState({ isLoaded: true }); } // // Render render() { const { className, style, size, lazy, overflow } = this.props; const { logoUrl, hasError, isLoaded } = this.state; if (hasError || !logoUrl) { return ( ); } if (lazy) { return ( } > ); } return ( ); } } ArtistLogo.propTypes = { className: PropTypes.string, style: PropTypes.object, images: PropTypes.arrayOf(PropTypes.object).isRequired, size: PropTypes.number.isRequired, lazy: PropTypes.bool.isRequired, overflow: PropTypes.bool.isRequired }; ArtistLogo.defaultProps = { size: 250, lazy: true, overflow: false }; export default ArtistLogo;