aboutsummaryrefslogblamecommitdiff
path: root/cmd/web/js/main.jsx
blob: e5e505d8daa5ef4ba301c5112b026bf4aebe69ae (plain) (tree)
1
2
3
4
5
6
7
8
9
10






                                                                     


                              



                                                        






































                                                





                           


































                                                                                                                               
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();
});