diff options
Diffstat (limited to 'web/react/components/signup_team.jsx')
-rw-r--r-- | web/react/components/signup_team.jsx | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/web/react/components/signup_team.jsx b/web/react/components/signup_team.jsx new file mode 100644 index 000000000..22086250c --- /dev/null +++ b/web/react/components/signup_team.jsx @@ -0,0 +1,78 @@ +// Copyright (c) 2015 Spinpunch, Inc. All Rights Reserved. +// See License.txt for license information. + + +var utils = require('../utils/utils.jsx'); +var client = require('../utils/client.jsx'); + +module.exports = React.createClass({ + handleSubmit: function(e) { + e.preventDefault(); + var team = {}; + var state = { server_error: "" }; + + team.email = this.refs.email.getDOMNode().value.trim().toLowerCase(); + if (!team.email || !utils.isEmail(team.email)) { + state.email_error = "Please enter a valid email address"; + state.inValid = true; + } + else { + state.email_error = ""; + } + + team.name = this.refs.name.getDOMNode().value.trim(); + if (!team.name) { + state.name_error = "This field is required"; + state.inValid = true; + } + else { + state.name_error = ""; + } + + if (state.inValid) { + this.setState(state); + return; + } + + client.signupTeam(team.email, team.name, + function(data) { + if (data["follow_link"]) { + window.location.href = data["follow_link"]; + } + else { + window.location.href = "/signup_team_confirm/?email=" + encodeURIComponent(team.email); + } + }.bind(this), + function(err) { + state.server_error = err.message; + this.setState(state); + }.bind(this) + ); + }, + getInitialState: function() { + return { }; + }, + render: function() { + + var email_error = this.state.email_error ? <label className='control-label'>{ this.state.email_error }</label> : null; + var name_error = this.state.name_error ? <label className='control-label'>{ this.state.name_error }</label> : null; + var server_error = this.state.server_error ? <div className={ "form-group has-error" }><label className='control-label'>{ this.state.server_error }</label></div> : null; + + return ( + <form role="form" onSubmit={this.handleSubmit}> + <div className={ email_error ? "form-group has-error" : "form-group" }> + <input type="email" ref="email" className="form-control" placeholder="Email Address" maxLength="128" /> + { email_error } + </div> + <div className={ name_error ? "form-group has-error" : "form-group" }> + <input type="text" ref="name" className="form-control" placeholder={utils.toTitleCase(strings.Company) + " Name"} maxLength="64" /> + { name_error } + </div> + { server_error } + <button className="btn btn-md btn-primary" type="submit">Sign up for Free</button> + </form> + ); + } +}); + + |