Created
January 22, 2018 19:30
-
-
Save frankfaustino/f36e6452b28ecc8b80c8c9f93632c6e1 to your computer and use it in GitHub Desktop.
Sign Up Page for LS Portfolio Project
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import React, { Component } from 'react' | |
import { connect } from 'react-redux' | |
import { FormControl, FormGroup } from 'react-bootstrap' | |
import { register } from '../Actions' | |
class SignUp extends Component { | |
constructor() { | |
super() | |
this.state = { | |
user: { | |
firstname: '', | |
lastname: '', | |
username: '', | |
password: '', | |
email: '', | |
question: 'dog', | |
answer: '', | |
role: 'student' | |
}, | |
submitted: false | |
} | |
this.handleChange = this.handleChange.bind(this) | |
this.handleSubmit = this.handleSubmit.bind(this) | |
} | |
handleChange(e) { | |
const { name, value } = e.target | |
const { user } = this.state | |
this.setState({ | |
user: { | |
...user, | |
[name]: value | |
} | |
}) | |
} | |
handleSubmit(e) { | |
e.preventDefault() | |
const { user } = this.state | |
const { dispatch } = this.props | |
this.setState({ submitted: true }) | |
if (user.firstname && user.lastname && user.username && user.password) { | |
dispatch(register(user)) | |
} | |
} | |
render() { | |
const { user, submitted } = this.state | |
const { registering } = this.props | |
return ( | |
<div className="container"> | |
<h2>Sign Up</h2> | |
<form> | |
<FormGroup> | |
<FormControl | |
className={'form-group' + (submitted && !user.firstname ? ' has-error' : '')} | |
onChange={this.handleChange} | |
placeholder="First Name" | |
type="text" | |
name="firstname" | |
value={this.state.firstname} | |
/> | |
{submitted && !user.firstname && <div className="help-block">First Name is required</div>} | |
<FormControl | |
className={'form-group' + (submitted && !user.lastname ? ' has-error' : '')} | |
onChange={this.handleChange} | |
placeholder="Last Name" | |
type="text" | |
name="lastname" | |
value={this.state.lastname} | |
/> | |
{submitted && !user.lastname && <div className="help-block">Last Name is required</div>} | |
<FormControl | |
className={'form-group' + (submitted && !user.email ? ' has-error' : '')} | |
onChange={this.handleChange} | |
placeholder="Email" | |
type="text" | |
name="email" | |
value={this.state.email} | |
/> | |
{submitted && !user.email && <div className="help-block">Email is required</div>} | |
<FormControl | |
className={'form-group' + (submitted && !user.username ? ' has-error' : '')} | |
onChange={this.handleChange} | |
placeholder="Username" | |
type="text" | |
name="username" | |
value={this.state.username} | |
/> | |
{submitted && !user.username && <div className="help-block">Username is required</div>} | |
<FormControl | |
className={'form-group' + (submitted && !user.password ? ' has-error' : '')} | |
onChange={this.handleChange} | |
placeholder="Password" | |
type="password" | |
name="password" | |
value={this.state.password} | |
/> | |
{submitted && !user.password && <div className="help-block">Password is required</div>} | |
<div className="buttons_layout" id="signup_btns"> | |
<label>Account Type:</label> | |
<select name="role" onChange={this.handleChange}> | |
<option disabled="true" placeholder="default"> | |
Account Type | |
</option> | |
<option value="student">Student</option> | |
<option value="instructor">Instructor</option> | |
<option value="recruiter">Recruiter</option> | |
<option value="general">General</option> | |
</select> | |
</div> | |
<div className="buttons_layout" id="signup_btns"> | |
<label>Security Question:</label> | |
<select name="question" onChange={this.handleChange}> | |
<option value="dog">What is your dog's name?</option> | |
<option value="color">What is your favorite color?</option> | |
<option value="schoolyear">What year did you graduate from high school?</option> | |
<option value="maidenname">What is your mother's maiden name?</option> | |
<option value="firstcar">What was the model of your first car?</option> | |
<option value="firstgrade">What was your first grade teacher's last name?</option> | |
<option value="city">In which city were you born?</option> | |
</select> | |
</div> | |
<FormControl | |
name="answer" | |
type="text" | |
onChange={this.handleChange} | |
value={this.state.answer} | |
/> | |
</FormGroup> | |
<button onClick={this.handleSubmit}> | |
Sign Up | |
</button> | |
{registering && ( | |
<img | |
alt="loading" | |
id="loading" | |
src="" | |
/> | |
)} | |
</form> | |
</div> | |
) | |
} | |
} | |
function mapStateToProps(state) { | |
const { registering } = state.registration | |
return { | |
registering | |
} | |
} | |
const connectedRegisterPage = connect(mapStateToProps)(SignUp) | |
export { connectedRegisterPage as SignUp } |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment