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.
Readarr/frontend/src/Artist/ArtistLogo.js

161 lines
5.3 KiB

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 (
<img
className={className}
style={style}
src={logoPlaceholder}
/>
);
}
if (lazy) {
return (
<LazyLoad
height={size}
offset={100}
overflow={overflow}
placeholder={
<img
className={className}
style={style}
src={logoPlaceholder}
/>
}
>
<img
className={className}
style={style}
src={logoUrl}
onError={this.onError}
/>
</LazyLoad>
);
}
return (
<img
className={className}
style={style}
src={isLoaded ? logoUrl : logoPlaceholder}
onError={this.onError}
onLoad={this.onLoad}
/>
);
}
}
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;