import _ from 'lodash'; import PropTypes from 'prop-types'; import React, { Component } from 'react'; import LazyLoad from 'react-lazyload'; const bannerPlaceholder = ''; function findBanner(images) { return _.find(images, { coverType: 'banner' }); } function getBannerUrl(banner, size) { if (banner) { if (banner.url.contains('lastWrite=') || (/^https?:/).test(banner.url)) { // Remove protocol let url = banner.url.replace(/^https?:/, ''); url = url.replace('banner.jpg', `banner-${size}.jpg`); return url; } } } class ArtistBanner extends Component { // // Lifecycle constructor(props, context) { super(props, context); const pixelRatio = Math.floor(window.devicePixelRatio); const { images, size } = props; const banner = findBanner(images); this.state = { pixelRatio, banner, bannerUrl: getBannerUrl(banner, pixelRatio * size), isLoaded: false, hasError: false }; } componentDidUpdate(prevProps) { const { images, size } = this.props; const { banner, pixelRatio } = this.state; const nextBanner = findBanner(images); if (nextBanner && (!banner || nextBanner.url !== banner.url)) { this.setState({ banner: nextBanner, bannerUrl: getBannerUrl(nextBanner, pixelRatio * size), hasError: false // Don't reset isLoaded, as we want to immediately try to // show the new image, whether an image was shown previously // or the placeholder was shown. }); // The poster could not be loaded.. if (!nextBanner && (this.props !== prevProps)) { this.setState({ banner: undefined, bannerUrl: bannerPlaceholder, hasError: true }); } } } // // Listeners onError = () => { this.setState({ hasError: true }); } onLoad = () => { this.setState({ isLoaded: true, hasError: false }); } // // Render render() { const { className, style, size, lazy, overflow } = this.props; const { bannerUrl, hasError, isLoaded } = this.state; if (hasError || !bannerUrl) { return ( ); } if (lazy) { return ( } > ); } return ( ); } } ArtistBanner.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 }; ArtistBanner.defaultProps = { size: 70, lazy: true, overflow: false }; export default ArtistBanner;