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 App from './app.js';
import Api from './api.js';
import cookies from './cookies.js';
import React from 'react';
-
-class Logo extends React.Component {
- render() {
- return <div className="row">
- <div id="logo" className="offset-4 col-4">
- <a href="/">Cryptoportfolio</a>
- </div>
- </div>;
- }
-}
+import qs from 'qs';
App.page('/signup', false, function(context) {
if (App.isUserSignedIn()) {
}
App.mount(<div>
- <Logo />
<SignupForm onSuccess={App.onUserSignUp}/>
</div>);
});
}
App.mount(<div>
- <Logo />
<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('/signout', true, function(context) {
cookies.removeItem('jwt');
App.page('/me', true, function(context) {
App.mount(<div>
- <Logo />
<PoloniexController/>
</div>);
});
App.page('/not_confirmed', true, function(context) {
App.mount(<div>
- <Logo />
<div className="row">
<div className="box offset-3 col-6 text-center">
<p>Please be patient, you account is being confirmed...</p>
}
App.mount(<div>
- <Logo />
<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>
- <Logo />
<OtpEnrollForm onSuccess={App.onUserValidateOtp} />
</div>);
});