import React from 'react'; import {Component} from 'react'; import './AddRemoteMount.css'; import {connect} from 'react-redux'; import Button from '../../components/UI/Button/Button'; import Box from '../../components/UI/Box/Box'; import Text from '../../components/UI/Text/Text'; import {notifyError} from '../../redux/actions/error_actions'; import {addRemoteMount} from '../../redux/actions/mount_actions'; import {createModalConditionally} from '../../utils'; const mapStateToProps = state => { return { RemoteMounts: state.mounts.RemoteMounts, }; }; const mapDispatchToProps = dispatch => { return { addRemoteMount: (hostNameOrIp, port, token) => dispatch(addRemoteMount(hostNameOrIp, port, token)), notifyError: (msg, critical, callback) => dispatch(notifyError(msg, critical, callback)), } }; export default connect(mapStateToProps, mapDispatchToProps)(class extends Component { state = { Display: false, HostNameOrIp: '', Port: 20000, Token: '', }; addRemoteMount = () => { if (this.state.HostNameOrIp.length === 0) { this.props.notifyError('Hostname or IP cannot be empty.'); } else { const provider = 'Remote' + this.state.HostNameOrIp + ':' + this.state.Port; if (this.props.RemoteMounts.includes(provider)) { this.props.notifyError('Remote host already exists'); } else { this.setState({ Display: false }, () => { this.props.addRemoteMount(this.state.HostNameOrIp, this.state.Port, this.state.Token); this.setState({ HostNameOrIp: '', Port: 20000, Token: '', }); }); } } }; handleAddRemoteMount = () => { this.setState({ Display: true, }); }; render() { const displayAdd = createModalConditionally(this.state.Display, (

Add Remote Mount

this.setState({HostNameOrIp: e.target.value.trim()})} className={'ConfigurationItemInput'} type={'text'} value={this.state.HostNameOrIp}/>
this.setState({Port: e.target.value})} className={'ConfigurationItemInput'} type={'number'} value={this.state.Port}/>
this.setState({Token: e.target.value})} className={'ConfigurationItemInput'} type={'text'} value={this.state.Token}/>
)); return (
{displayAdd}
); } });