import React from 'react'; import PropTypes from 'prop-types'; import { Text, ScrollView, View, SafeAreaView, Keyboard } from 'react-native'; import { connect } from 'react-redux'; import { serverRequest, addServer } from '../actions/server'; import KeyboardView from '../presentation/KeyboardView'; import styles from './Styles'; import scrollPersistTaps from '../utils/scrollPersistTaps'; import Button from '../containers/Button'; import TextInput from '../containers/TextInput'; import Loading from '../containers/Loading'; import LoggedView from './View'; @connect(state => ({ validInstance: !state.server.failure && !state.server.connecting, validating: state.server.connecting, addingServer: state.server.adding }), dispatch => ({ validateServer: url => dispatch(serverRequest(url)), addServer: url => dispatch(addServer(url)) })) export default class NewServerView extends LoggedView { static propTypes = { validateServer: PropTypes.func.isRequired, addServer: PropTypes.func.isRequired, validating: PropTypes.bool.isRequired, validInstance: PropTypes.bool.isRequired, addingServer: PropTypes.bool.isRequired, navigation: PropTypes.object.isRequired } constructor(props) { super('NewServerView', props); this.state = { defaultServer: 'https://open.rocket.chat' }; this.props.validateServer(this.state.defaultServer); // Need to call because in case of submit with empty field } componentDidMount() { this.input.focus(); } onChangeText = (text) => { this.setState({ text }); this.props.validateServer(this.completeUrl(text)); } submit = () => { Keyboard.dismiss(); this.props.addServer(this.completeUrl(this.state.text)); } completeUrl = (url) => { url = url && url.trim(); if (!url) { return this.state.defaultServer; } if (/^(\w|[0-9-_]){3,}$/.test(url) && /^(htt(ps?)?)|(loca((l)?|(lh)?|(lho)?|(lhos)?|(lhost:?\d*)?)$)/.test(url) === false) { url = `${ url }.rocket.chat`; } if (/^(https?:\/\/)?(((\w|[0-9])+(\.(\w|[0-9-_])+)+)|localhost)(:\d+)?$/.test(url)) { if (/^localhost(:\d+)?/.test(url)) { url = `http://${ url }`; } else if (/^https?:\/\//.test(url) === false) { url = `https://${ url }`; } } return url.replace(/\/+$/, ''); } renderValidation = () => { if (this.props.validating) { return ( Validating {this.state.text || 'open'} ... ); } if (this.props.validInstance) { return ( {this.state.url} is a valid Rocket.Chat instance ); } return ( {this.state.url} is not a valid Rocket.Chat instance ); } render() { const { validInstance } = this.props; return ( Sign in your server this.input = e} containerStyle={{ marginBottom: 5 }} label='Your server' placeholder={this.state.defaultServer} returnKeyType='done' onChangeText={this.onChangeText} onSubmitEditing={this.submit} /> {this.renderValidation()}