1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-22 23:56:53 +01:00
onion/js/components/signup_container.js

64 lines
1.7 KiB
JavaScript
Raw Normal View History

2015-06-20 16:43:18 +02:00
import React from 'react';
import Link from 'react-router/es6/Link';
2015-07-13 16:57:25 +02:00
import SignupForm from './ascribe_forms/form_signup';
2015-06-20 16:43:18 +02:00
import withContext from './context/with_context';
import { whitelabelShape } from './prop_types';
import { setDocumentTitle } from '../utils/dom';
import { getLangText } from '../utils/lang';
2015-06-20 16:43:18 +02:00
2015-06-22 10:50:22 +02:00
let SignupContainer = React.createClass({
propTypes: {
// Injected through HOCs
2016-06-08 14:54:05 +02:00
whitelabel: whitelabelShape.isRequired
},
getInitialState() {
2015-07-13 16:57:25 +02:00
return {
2015-06-22 10:50:22 +02:00
submitted: false,
message: null
2015-07-13 16:57:25 +02:00
};
},
handleSuccess(message) {
2015-06-22 10:50:22 +02:00
this.setState({
submitted: true,
message: message
});
},
2015-06-20 16:43:18 +02:00
render() {
2016-06-08 14:54:05 +02:00
const { whitelabel: { name: whitelabelName } } = this.props;
const { message, submitted } = this.state;
setDocumentTitle(getLangText('Sign up'));
if (submitted) {
2015-06-22 10:50:22 +02:00
return (
<div className="ascribe-login-wrapper">
<br/>
<div className="ascribe-login-text ascribe-login-header">
{message}
2015-06-22 10:50:22 +02:00
</div>
</div>
);
}
2015-06-20 16:43:18 +02:00
return (
<div className="ascribe-login-wrapper">
<SignupForm
handleSuccess={this.handleSuccess}
2016-06-08 14:54:05 +02:00
whitelabelName={whitelabelName} />
<div className="ascribe-login-text">
{getLangText(`Already a ${whitelabelName || 'ascribe'} user`)}&#63; <Link to="/login">{getLangText('Log in')}...</Link><br/>
</div>
2015-06-20 16:43:18 +02:00
</div>
2015-06-20 16:43:18 +02:00
);
}
});
export default withContext(SignupContainer, 'whitelabel');