'use strict'; import React from 'react'; import GlobalNotificationModel from '../../models/global_notification_model'; import GlobalNotificationActions from '../../actions/global_notification_actions'; import UserActions from '../../actions/user_actions'; import Form from './form'; import Property from './property'; import InputCheckbox from './input_checkbox'; import AscribeSpinner from '../ascribe_spinner'; import withContext from '../context/with_context'; import { locationShape } from '../prop_types'; import { getLangText } from '../../utils/lang'; import { resolveUrl } from '../../utils/url_resolver'; let SignupForm = React.createClass({ propTypes: { headerMessage: React.PropTypes.string, submitMessage: React.PropTypes.string, handleSuccess: React.PropTypes.func, children: React.PropTypes.oneOfType([ React.PropTypes.arrayOf(React.PropTypes.element), React.PropTypes.element, React.PropTypes.string ]), whitelabelName: React.PropTypes.string, // Injected through HOCs isLoggedIn: locationShape.isRequired, // eslint-disable-line react/sort-prop-types }, getDefaultProps() { return { headerMessage: getLangText('Welcome to ascribe'), submitMessage: getLangText('Sign up') }; }, handleSuccess(response) { if (response.user) { const notification = new GlobalNotificationModel(getLangText('Sign up successful'), 'success', 50000); GlobalNotificationActions.appendGlobalNotification(notification); // Refactor this to its own component this.props.handleSuccess(getLangText('We sent an email to your address') + ' ' + response.user.email + ', ' + getLangText('please confirm') + '.'); } else { UserActions.fetchCurrentUser(true); } }, getFormData() { const { token } = this.props.location.query; return token ? { token } : null; }, render() { const { children, headerMessage, location: { query: { email: emailQuery } }, submitMessage, whitelabelName } = this.props; return (
); } }); export default withContext(SignupForm, 'location');