From cf40b3c5e25922c9890b7b38ac492984ce1d8c31 Mon Sep 17 00:00:00 2001 From: rheo-chiti Date: Sat, 22 Feb 2020 17:36:54 +0530 Subject: [PATCH] View Password feature --- client/src/pages/SignUpForm.js | 135 +++++++++++++++++++++------------ 1 file changed, 88 insertions(+), 47 deletions(-) diff --git a/client/src/pages/SignUpForm.js b/client/src/pages/SignUpForm.js index 48636c6..5492dfd 100644 --- a/client/src/pages/SignUpForm.js +++ b/client/src/pages/SignUpForm.js @@ -1,67 +1,108 @@ import React, { Component } from 'react'; import { Link } from 'react-router-dom'; +import IconButton from '@material-ui/core/IconButton'; +import VisibilityOffIcon from '@material-ui/icons/VisibilityOff'; +import VisibilityIcon from '@material-ui/icons/Visibility'; + class SignUpForm extends Component { - constructor() { - super(); + constructor() { + super(); - this.state = { - email: '', - password: '', - name: '', - hasAgreed: false - }; + this.state = { + email: '', + password: '', + name: '', + hasAgreed: false, + disabledButtonColor: '#9fcfff', + disabledTextColor: '#808080', + type: 'password', + Icon: + }; - this.handleChange = this.handleChange.bind(this); - this.handleSubmit = this.handleSubmit.bind(this); - } + this.handleChange = this.handleChange.bind(this); + this.handleSubmit = this.handleSubmit.bind(this); + } - handleChange(e) { - let target = e.target; - let value = target.type === 'checkbox' ? target.checked : target.value; - let name = target.name; + handleChange(e) { + let target = e.target; + let value = target.type === 'checkbox' ? target.checked : target.value; + let name = target.name; - this.setState({ - [name]: value - }); - } + this.setState({ + [name]: value + }); + } + + handleClick = () => this.setState(({ type }) => ({ + Icon: type === 'text' ? : , + type: type === 'text' ? 'password' : 'text' + + })) - handleSubmit(e) { - e.preventDefault(); + handleSubmit(e) { + e.preventDefault(); - console.log('The form was submitted with the following data:'); - console.log(this.state); + console.log('The form was submitted with the following data:'); + console.log(this.state); + } + + render() { + + let content = null; + if (this.state.email.length && this.state.password.length && this.state.name.length && this.state.hasAgreed) { + content = + } + else { + content = } - render() { - return ( + return ( +
-
-
- - -
+ +
+ + +
+
- -
-
- - +
+ + {this.state.Icon} + +
+
+ + +
-
- -
+
+ +
-
- I'm already member -
-
-
- ); - } +
+ {content} + I'm already member +
+ +
+ + ); + } } export default SignUpForm; \ No newline at end of file