Advertisement
Guest User

Untitled

a guest
Jan 23rd, 2019
93
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. import React from 'react';
  2.  
  3. class Register extends React.Component {
  4.   constructor(props) {
  5.     super(props);
  6.     this.state = {
  7.       email: '',
  8.       password: '',
  9.       name: ''
  10.     }
  11.   }
  12.  
  13.   onNameChange = (event) => {
  14.     this.setState({name: event.target.value});
  15.   }
  16.  
  17.   onEmailChange = (event) => {
  18.     this.setState({email: event.target.value})
  19.   }
  20.  
  21.   onPwdChange = (event) => {
  22.     this.setState({password: event.target.value})
  23.   }
  24.  
  25.   onSubmitSignIn = () => {
  26.     fetch('http://localhost:3001/register', {
  27.       method: 'post',
  28.       headers: {'Content-Type': 'application/json'},
  29.       body: JSON.stringify({
  30.         email: this.state.email,
  31.         password: this.state.password,
  32.         name: this.state.name
  33.       })
  34.     })
  35.     .then(response => response.json())
  36.     .then(user => {
  37.       if(user === 'success') {
  38.         this.props.loadUser(user);
  39.         this.props.onRouteChange('home');
  40.       }
  41.     });
  42.   }
  43.  
  44.   render() {
  45.     return (
  46.       <article className="br3 ba dark-gray b--black-10 mv4 w-100 w-50-m w-25-l mw6 shadow-5 center">
  47.         <main className="pa4 black-80">
  48.           <div className="measure">
  49.             <fieldset id="sign_up" className="ba b--transparent ph0 mh0" >
  50.               <legend className="f1 fw6 ph0 mh0">Register</legend>
  51.               <div className="mt3">
  52.                 <label className="db fw6 lh-copy f6" htmlFor="name">Name (Full)</label>
  53.                 <input onChange={this.onNameChange} className="pa2 input-reset ba bg-transparent hover-bg-black hover-white w-100" type="text" name="name" id="name" />
  54.               </div>
  55.               <div className="mt3">
  56.                 <label className="db fw6 lh-copy f6" htmlFor="email-address">Email</label>
  57.                 <input onChange={this.onEmailChange} className="pa2 input-reset ba bg-transparent hover-bg-black hover-white w-100" type="email" name="email-address"  id="email-address" />
  58.               </div>
  59.               <div className="mv3">
  60.                 <label className="db fw6 lh-copy f6" htmlFor="password">Password</label>
  61.                 <input onChange={this.onPwdChange} className="b pa2 input-reset ba bg-transparent hover-bg-black hover-white w-100" type="password" name="password"  id="password" />
  62.               </div>
  63.             </fieldset>
  64.             <div className="">
  65.               <input onClick={this.onSubmitSignIn} className="b ph3 pv2 input-reset ba b--black bg-transparent grow pointer f6 dib" type="submit" value="Register" />
  66.             </div>
  67.           </div>
  68.         </main>
  69.       </article>
  70.     );
  71.   }
  72. }
  73.  
  74. export default Register;
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement