From 8554c0d9cb18d9fcb0b5498462a1d2bb065df4a6 Mon Sep 17 00:00:00 2001 From: Bogdan Date: Sun, 17 Dec 2023 19:57:22 +0200 Subject: [PATCH] Refactor movie alternative titles connector --- .../MovieTitlesTableContentConnector.js | 42 +++++++++++++------ 1 file changed, 29 insertions(+), 13 deletions(-) diff --git a/frontend/src/Movie/Details/Titles/MovieTitlesTableContentConnector.js b/frontend/src/Movie/Details/Titles/MovieTitlesTableContentConnector.js index 136a7e994..112ad88b2 100644 --- a/frontend/src/Movie/Details/Titles/MovieTitlesTableContentConnector.js +++ b/frontend/src/Movie/Details/Titles/MovieTitlesTableContentConnector.js @@ -6,31 +6,43 @@ import MovieTitlesTableContent from './MovieTitlesTableContent'; function createMapStateToProps() { return createSelector( + (state, { movieId }) => movieId, (state) => state.movies, - (movies) => { - return movies; + (movieId, movies) => { + const { + isFetching, + isPopulated, + error, + items + } = movies; + + const alternateTitles = items.find((m) => m.id === movieId)?.alternateTitles; + + return { + isFetching, + isPopulated, + error, + alternateTitles + }; } ); } -const mapDispatchToProps = { -// fetchMovies -}; - class MovieTitlesTableContentConnector extends Component { // // Render render() { - const movie = this.props.items.filter((obj) => { - return obj.id === this.props.movieId; - }); + const { + alternateTitles, + ...otherProps + } = this.props; return ( ); } @@ -38,7 +50,11 @@ class MovieTitlesTableContentConnector extends Component { MovieTitlesTableContentConnector.propTypes = { movieId: PropTypes.number.isRequired, - items: PropTypes.arrayOf(PropTypes.object).isRequired + alternateTitles: PropTypes.arrayOf(PropTypes.object).isRequired }; -export default connect(createMapStateToProps, mapDispatchToProps)(MovieTitlesTableContentConnector); +MovieTitlesTableContentConnector.defaultProps = { + alternateTitles: [] +}; + +export default connect(createMapStateToProps)(MovieTitlesTableContentConnector);