forked from hasura/auth-ui-kit
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathForgotPasswordEmail.js
115 lines (111 loc) · 3.61 KB
/
ForgotPasswordEmail.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
import React, { Component } from 'react';
import { Helmet } from 'react-helmet';
import './style.css';
import SignUpMessage from './SignUpMessage';
import Back from './Back';
import ErrorMsg from './ErrorMsg';
import globals from './globals';
import { emailForgotPassword } from './api';
class ForgotPasswordEmail extends Component {
state = {
isProgressing: false,
response: null,
};
enterProgressing = status => {
this.setState({ isProgressing: status });
};
authRespCallback = resp => {
this.setState({ response: resp });
};
render() {
const pageWrapperThemeClass =
globals.theme === 'light'
? 'LightLandingPageWrapper'
: 'DarkLandingPageWrapper';
const pageInnerThemeClass =
globals.theme === 'light'
? 'LightLandingPageInnerWrapper'
: 'DarkLandingPageInnerWrapper';
const formGroupThemeClass =
globals.theme === 'light'
? 'LightFormGroupWrapper'
: 'DarkFormGroupWrapper';
const headerDescriptionClass =
globals.theme === 'light'
? 'lightHeaderDescription'
: 'darkHeaderDescription';
let submitBtnText = 'Send Email';
if (this.state.isProgressing) {
submitBtnText = (
<span>
<i className="fa fa-spinner fa-spin" /> Sending Email..
</span>
);
}
return (
<div
className={
'displayFlex landingPageWrapper container-fluid ' +
pageWrapperThemeClass
}
>
<Helmet>
<meta charSet="utf-8" />
<title>Forgot Password</title>
</Helmet>
<div className={'landingPageInnerWidth'}>
<Back backUrl={'/ui/login/email'} />
<div className={'landingPageInnerWrapper ' + pageInnerThemeClass}>
<div className="signUpWrapper">
<div className={headerDescriptionClass}>Forgot Password</div>
<div className="descriptionText">
Hello! Submit your email to reset your password
</div>
<ErrorMsg response={this.state.response} />
<form
className={formGroupThemeClass}
onChange={() => {
this.setState({ response: null });
}}
onSubmit={e => {
e.preventDefault();
if (this.email.value !== '') {
this.enterProgressing(true);
emailForgotPassword(this.email.value)
.then(resp => {
this.enterProgressing(false);
alert('Email Sent. Please check your inbox');
})
.catch(resp => {
this.enterProgressing(false);
this.setState({ response: resp });
});
} else {
alert('Enter an email id to send a forgot password email');
}
}}
>
<div className="formInput">
<label className="formLabel">Email ID</label>
<input
type="email"
ref={input => {
this.email = input;
}}
/>
</div>
<div className="signInbtn">
<a>
<button type="submit">{submitBtnText}</button>
</a>
</div>
</form>
</div>
</div>
<SignUpMessage location={this.props.location} />
</div>
</div>
);
}
}
export default ForgotPasswordEmail;