import PropTypes from 'prop-types'; import React, { Component } from 'react'; import { connect } from 'react-redux'; import { createSelector } from 'reselect'; import { fetchLanguageProfiles, deleteLanguageProfile, cloneLanguageProfile } from 'Store/Actions/settingsActions'; import LanguageProfiles from './LanguageProfiles'; function createMapStateToProps() { return createSelector( (state) => state.settings.advancedSettings, (state) => state.settings.languageProfiles, (advancedSettings, languageProfiles) => { return { advancedSettings, ...languageProfiles }; } ); } const mapDispatchToProps = { dispatchFetchLanguageProfiles: fetchLanguageProfiles, dispatchDeleteLanguageProfile: deleteLanguageProfile, dispatchCloneLanguageProfile: cloneLanguageProfile }; class LanguageProfilesConnector extends Component { // // Lifecycle componentDidMount() { this.props.dispatchFetchLanguageProfiles(); } // // Listeners onConfirmDeleteLanguageProfile = (id) => { this.props.dispatchDeleteLanguageProfile({ id }); } onCloneLanguageProfilePress = (id) => { this.props.dispatchCloneLanguageProfile({ id }); } // // Render render() { return ( ); } } LanguageProfilesConnector.propTypes = { dispatchFetchLanguageProfiles: PropTypes.func.isRequired, dispatchDeleteLanguageProfile: PropTypes.func.isRequired, dispatchCloneLanguageProfile: PropTypes.func.isRequired }; export default connect(createMapStateToProps, mapDispatchToProps)(LanguageProfilesConnector);