Radarr/frontend/src/InteractiveImport/Movie/SelectMovieModalContentConn...

116 lines
2.7 KiB
JavaScript
Raw Normal View History

2018-11-23 07:04:42 +00:00
import PropTypes from 'prop-types';
import React, { Component } from 'react';
import { connect } from 'react-redux';
import { createSelector } from 'reselect';
import { reprocessInteractiveImportItems, updateInteractiveImportItem } from 'Store/Actions/interactiveImportActions';
2018-11-23 07:04:42 +00:00
import createAllMoviesSelector from 'Store/Selectors/createAllMoviesSelector';
import createDeepEqualSelector from 'Store/Selectors/createDeepEqualSelector';
import SelectMovieModalContent from './SelectMovieModalContent';
2018-11-23 07:04:42 +00:00
function createCleanMovieSelector() {
2018-11-23 07:04:42 +00:00
return createSelector(
createAllMoviesSelector(),
(items) => {
return items.map((movie) => {
const {
id,
title,
titleSlug,
sortTitle,
year,
images,
alternateTitles = []
} = movie;
return {
id,
title,
titleSlug,
sortTitle,
year,
images,
alternateTitles,
firstCharacter: title.charAt(0).toLowerCase()
};
}).sort((a, b) => {
if (a.sortTitle < b.sortTitle) {
return -1;
}
2018-11-23 07:04:42 +00:00
if (a.sortTitle > b.sortTitle) {
return 1;
}
2018-11-23 07:04:42 +00:00
return 0;
});
}
);
}
function createMapStateToProps() {
return createDeepEqualSelector(
createCleanMovieSelector(),
(movies) => {
return {
items: movies
2018-11-23 07:04:42 +00:00
};
}
);
}
const mapDispatchToProps = {
dispatchReprocessInteractiveImportItems: reprocessInteractiveImportItems,
dispatchUpdateInteractiveImportItem: updateInteractiveImportItem
2018-11-23 07:04:42 +00:00
};
class SelectMovieModalContentConnector extends Component {
2018-11-23 07:04:42 +00:00
//
// Listeners
onMovieSelect = (movieId) => {
const {
ids,
items,
dispatchUpdateInteractiveImportItem,
dispatchReprocessInteractiveImportItems,
onModalClose
} = this.props;
2018-11-23 07:04:42 +00:00
const movie = items.find((s) => s.id === movieId);
ids.forEach((id) => {
dispatchUpdateInteractiveImportItem({
2018-11-23 07:04:42 +00:00
id,
movie
2018-11-23 07:04:42 +00:00
});
});
dispatchReprocessInteractiveImportItems({ ids });
onModalClose(true);
};
2018-11-23 07:04:42 +00:00
//
// Render
render() {
return (
<SelectMovieModalContent
2018-11-23 07:04:42 +00:00
{...this.props}
onMovieSelect={this.onMovieSelect}
/>
);
}
}
SelectMovieModalContentConnector.propTypes = {
2018-11-23 07:04:42 +00:00
ids: PropTypes.arrayOf(PropTypes.number).isRequired,
items: PropTypes.arrayOf(PropTypes.object).isRequired,
dispatchReprocessInteractiveImportItems: PropTypes.func.isRequired,
dispatchUpdateInteractiveImportItem: PropTypes.func.isRequired,
2018-11-23 07:04:42 +00:00
onModalClose: PropTypes.func.isRequired
};
export default connect(createMapStateToProps, mapDispatchToProps)(SelectMovieModalContentConnector);