'use strict'; import React from 'react'; import Router from 'react-router'; import { getLangText } from '../../utils/lang_utils'; import UserStore from '../../stores/user_store'; import GlobalNotificationModel from '../../models/global_notification_model'; import GlobalNotificationActions from '../../actions/global_notification_actions'; import Form from './form'; import Property from './property'; import InputCheckbox from './input_checkbox'; import AppConstants from '../../constants/application_constants'; import ApiUrls from '../../constants/api_urls'; let SignupForm = React.createClass({ propTypes: { headerMessage: React.PropTypes.string, submitMessage: React.PropTypes.string, handleSuccess: React.PropTypes.func, children: React.PropTypes.element }, mixins: [Router.Navigation, Router.State], getDefaultProps() { return { headerMessage: getLangText('Welcome to ascribe'), submitMessage: getLangText('Sign up') }; }, getInitialState() { return UserStore.getState(); }, componentDidMount() { UserStore.listen(this.onChange); let { redirect } = this.getQuery(); if (redirect && redirect !== 'signup'){ this.transitionTo(redirect, null, this.getQuery()); } }, componentWillUnmount() { UserStore.unlisten(this.onChange); }, onChange(state) { this.setState(state); // if user is already logged in, redirect him to piece list if(this.state.currentUser && this.state.currentUser.email) { let { redirectAuthenticated } = this.getQuery(); if ( redirectAuthenticated) { /* * redirectAuthenticated contains an arbirary path * eg pieces/, editions/, collection, settings, ... * hence transitionTo cannot be used directly */ window.location = AppConstants.baseUrl + redirectAuthenticated; } window.setTimeout(() => this.transitionTo('pieces')); } }, handleSuccess(response){ if (response.user) { let notification = new GlobalNotificationModel(getLangText('Sign up successful'), 'success', 50000); GlobalNotificationActions.appendGlobalNotification(notification); this.props.handleSuccess(getLangText('We sent an email to your address') + ' ' + response.user.email + ', ' + getLangText('please confirm') + '.'); } else if (response.redirect) { let { redirectAuthenticated } = this.getQuery(); if ( redirectAuthenticated) { /* * redirectAuthenticated contains an arbirary path * eg pieces/, editions/, collection, settings, ... * hence transitionTo cannot be used directly */ window.location = AppConstants.baseUrl + redirectAuthenticated; } this.transitionTo('pieces'); } }, getFormData() { if (this.getQuery().token){ return {token: this.getQuery().token}; } return null; }, render() { let tooltipPassword = getLangText('Your password must be at least 10 characters') + '.\n ' + getLangText('This password is securing your digital property like a bank account') + '.\n ' + getLangText('Store it in a safe place') + '!'; let email = this.getQuery().email || null; return (
{this.props.submitMessage} } spinner={ }>

{this.props.headerMessage}

{this.props.children} {' ' + getLangText('I agree to the Terms of Service of ascribe') + ' '} ( {getLangText('read')} )
); } }); export default SignupForm;