import PropTypes from 'prop-types'; import React, { Component } from 'react'; import { connect } from 'react-redux'; import { createSelector } from 'reselect'; import AddNewMovieModalContent from 'AddMovie/AddNewMovie/AddNewMovieModalContent'; import { addMovie, setAddMovieDefault } from 'Store/Actions/discoverMovieActions'; import createDimensionsSelector from 'Store/Selectors/createDimensionsSelector'; import createSystemStatusSelector from 'Store/Selectors/createSystemStatusSelector'; import selectSettings from 'Store/Selectors/selectSettings'; function createMapStateToProps() { return createSelector( (state) => state.discoverMovie, createDimensionsSelector(), createSystemStatusSelector(), (discoverMovieState, dimensions, systemStatus) => { const { isAdding, addError, defaults } = discoverMovieState; const { settings, validationErrors, validationWarnings } = selectSettings(defaults, {}, addError); return { isAdding, addError, isSmallScreen: dimensions.isSmallScreen, validationErrors, validationWarnings, isWindows: systemStatus.isWindows, ...settings }; } ); } const mapDispatchToProps = { setAddMovieDefault, addMovie }; class AddNewDiscoverMovieModalContentConnector extends Component { // // Listeners onInputChange = ({ name, value }) => { this.props.setAddMovieDefault({ [name]: value }); } onAddMoviePress = (searchForMovie) => { const { tmdbId, rootFolderPath, monitor, qualityProfileId, minimumAvailability, tags } = this.props; this.props.addMovie({ tmdbId, rootFolderPath: rootFolderPath.value, monitor: monitor.value, qualityProfileId: qualityProfileId.value, minimumAvailability: minimumAvailability.value, tags: tags.value, searchForMovie }); this.props.onModalClose(true); } // // Render render() { return ( ); } } AddNewDiscoverMovieModalContentConnector.propTypes = { tmdbId: PropTypes.number.isRequired, rootFolderPath: PropTypes.object, monitor: PropTypes.object.isRequired, qualityProfileId: PropTypes.object, minimumAvailability: PropTypes.object.isRequired, tags: PropTypes.object.isRequired, onModalClose: PropTypes.func.isRequired, setAddMovieDefault: PropTypes.func.isRequired, addMovie: PropTypes.func.isRequired }; export default connect(createMapStateToProps, mapDispatchToProps)(AddNewDiscoverMovieModalContentConnector);