aboutsummaryrefslogtreecommitdiff
path: root/cmd/web/js/main.jsx
blob: e5e505d8daa5ef4ba301c5112b026bf4aebe69ae (plain) (blame)
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();
});