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
|
var SignupForm = require('./signup.js').SignupForm;
var SigninForm = require('./signin.js').SigninForm;
var OtpEnrollForm = require('./otp.js').OtpEnrollForm;
var PoloniexController = require('./poloniex.js').PoloniexController;
var App = require('./app.js');
var Api = require('./api.js').Api;
var cookies = require('./cookies.js');
var Logo = React.createClass({
render: function() {
return (<div className='row'>
<div id='logo' className='offset-4 col-4'>
<a href='/'>Cryptoportfolio</a>
</div>
</div>);
}
});
App.page('/signup', false, function(context) {
if (App.isUserSignedIn()) {
App.go('/me');
return;
}
App.mount(
<div>
<Logo />
<SignupForm onSuccess={App.onUserSignUp}/>
</div>
);
});
App.page('/signin', false, function(context) {
if (App.isUserSignedIn()) {
App.go('/me');
return;
}
App.mount(
<div>
<Logo />
<SigninForm onSuccess={App.onUserSignIn}/>
</div>
);
});
App.page('/signout', true, function(context) {
cookies.removeItem('jwt');
App.go('/');
});
App.page('/me', true, function(context) {
App.mount(
<div>
<Logo />
<PoloniexController/>
</div>
);
});
App.page('/otp/setup', true, function(context) {
Api.Call('OTP_ENROLL', {}, function(err, status, data) {
if (err) {
console.error(err, data);
return;
}
App.mount(
<div>
<Logo />
<OtpEnrollForm onSuccess={App.onUserValidateOtp} img={'data:image/png;base64,' + data.base64img} secret={data.secret}/>
</div>
);
}.bind(this));
});
App.page('/otp/validate', true, function(context) {
App.mount(
<div>
<Logo />
<OtpEnrollForm onSuccess={App.onUserValidateOtp} />
</div>
);
});
App.page('/', false, function(context) {
App.go('/me');
});
$(document).ready(function() {
App.start();
});
|