import _ from 'lodash'; import PropTypes from 'prop-types'; import React, { Component } from 'react'; import { connect } from 'react-redux'; import { createSelector } from 'reselect'; import createCommandsSelector from 'Store/Selectors/createCommandsSelector'; import createQualityProfileSelector from 'Store/Selectors/createQualityProfileSelector'; import createLanguageProfileSelector from 'Store/Selectors/createLanguageProfileSelector'; import { executeCommand } from 'Store/Actions/commandActions'; import * as commandNames from 'Commands/commandNames'; function createMapStateToProps() { return createSelector( (state, { id }) => id, (state, { albums }) => albums, createQualityProfileSelector(), createLanguageProfileSelector(), createCommandsSelector(), (artistId, albums, qualityProfile, languageProfile, commands) => { const isRefreshingArtist = _.some(commands, (command) => { return command.name === commandNames.REFRESH_ARTIST && command.body.artistId === artistId; }); const latestAlbum = _.first(_.orderBy(albums, 'releaseDate', 'desc')); return { qualityProfile, languageProfile, latestAlbum, isRefreshingArtist }; } ); } const mapDispatchToProps = { executeCommand }; class ArtistIndexItemConnector extends Component { // // Listeners onRefreshArtistPress = () => { this.props.executeCommand({ name: commandNames.REFRESH_ARTIST, artistId: this.props.id }); } // // Render render() { const { component: ItemComponent, ...otherProps } = this.props; return ( ); } } ArtistIndexItemConnector.propTypes = { id: PropTypes.number.isRequired, component: PropTypes.func.isRequired, executeCommand: PropTypes.func.isRequired }; export default connect(createMapStateToProps, mapDispatchToProps)(ArtistIndexItemConnector);