import SignupForm from './signup.js';
import SigninForm from './signin.js';
+import PasswordResetForm from './password_reset.js';
+import ChangePasswordForm from './change_password.js';
import OtpEnrollForm from './otp.js';
import PoloniexController from './poloniex.js';
+import UserAccount from './account.js';
import App from './app.js';
import Api from './api.js';
import cookies from './cookies.js';
import React from 'react';
-
-class Header extends React.Component {
- render = () => {
- if (this.props.displayLogout === true) {
- return <div id="header" className="row">
- <div className="offset-4 col-4">
- <Logo />
- </div>
- <div className="offset-2 col-2 align-self-center h-100">
- <a href="/signout"><u>Logout</u></a>
- </div>
- </div>;
- }
- return <div id="header" className="row">
- <div className="offset-4 col-4">
- <Logo />
- </div>
- </div>;
-
- }
-}
-
-class Logo extends React.Component {
- render() {
- return <div id="logo" className="w-100 h-100 align-self-center">
- <h1><a href="/">CryptoPF</a></h1>
- </div>;
- }
-}
+import qs from 'qs';
App.page('/signup', false, function(context) {
if (App.isUserSignedIn()) {
}
App.mount(<div>
- <Header />
<SignupForm onSuccess={App.onUserSignUp}/>
</div>);
});
}
App.mount(<div>
- <Header />
<SigninForm onSuccess={App.onUserSignIn}/>
</div>);
});
+App.page('/reset-password', false, function(context) {
+ if (App.isUserSignedIn()) {
+ App.go('/me');
+ return;
+ }
+
+ App.mount(<div>
+ <PasswordResetForm />
+ </div>);
+});
+
+App.page('/change-password', false, function(context) {
+ if (App.isUserSignedIn()) {
+ App.go('/me');
+ return;
+ }
+
+ var token = qs.parse(context.querystring).token;
+
+ if (token === undefined) {
+ App.go('/');
+ return;
+ }
+
+ App.mount(<div>
+ <ChangePasswordForm token={token} onSuccess={App.go.bind(App, '/signin')}/>
+ </div>);
+});
+
+App.page('/confirm', false, function(context) {
+ var token = qs.parse(context.querystring).token;
+
+ if (token === undefined) {
+ App.go('/');
+ return;
+ }
+
+ Api.Call(
+ 'CONFIRM_EMAIL',
+ {'token': token},
+ function(err, status, data) {
+ if (err) {
+ console.error(err, data);
+ }
+
+ App.go('/me');
+ }
+ );
+});
+
App.page('/signout', true, function(context) {
cookies.removeItem('jwt');
App.page('/me', true, function(context) {
App.mount(<div>
- <Header displayLogout={true} />
<PoloniexController/>
</div>);
});
+App.page('/account', true, function(context) {
+ App.mount(<div>
+ <UserAccount/>
+ </div>);
+});
+
App.page('/not_confirmed', true, function(context) {
App.mount(<div>
- <Header displayLogout={true}/>
<div className="row">
<div className="box offset-3 col-6 text-center">
- <p>Please be patient, you account is being confirmed...</p>
- <p><a href="/me"><u>Refresh</u></a></p>
+ <p>An email has now been sent to your email address.</p>
+ <p>{'Please click the \'Confirm your account\' button to validate your email.'}</p>
</div>
</div>
</div>);
}
App.mount(<div>
- <Header displayLogout={true}/>
<OtpEnrollForm onSuccess={App.onUserValidateOtp} img={'data:image/png;base64,' + data.base64img} secret={data.secret}/>
</div>);
App.page('/otp/validate', true, function(context) {
App.mount(<div>
- <Header displayLogout={true}/>
<OtpEnrollForm onSuccess={App.onUserValidateOtp} />
</div>);
});