InstallerForm.js 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. import React from 'react';
  2. import PropTypes from 'prop-types';
  3. import i18next from 'i18next';
  4. import { translate } from 'react-i18next';
  5. class InstallerForm extends React.Component {
  6. constructor(props) {
  7. super(props);
  8. this.state = {
  9. isValidUserName: true,
  10. };
  11. this.checkUserName = this.checkUserName.bind(this);
  12. }
  13. checkUserName(e) {
  14. $.getJSON('/_api/check_username', {username: e.target.value}, function(json) {
  15. this.setState({ isValidUserName: json.valid });
  16. }.bind(this));
  17. }
  18. changeLanguage(locale) {
  19. i18next.changeLanguage(locale);
  20. }
  21. render() {
  22. const hasErrorClass = this.state.isValidUserName ? '' : ' has-error';
  23. const unavailableUserId = this.state.isValidUserName ? '' : <span><i className="icon-fw icon-ban" />{ this.props.t('installer.unavaliable_user_id') }</span>;
  24. return (
  25. <div className={'login-dialog p-t-10 p-b-10 col-sm-offset-4 col-sm-4' + hasErrorClass}>
  26. <p className="alert alert-success">
  27. <strong>{ this.props.t('installer.create_initial_account') }</strong><br />
  28. <small>{ this.props.t('installer.initial_account_will_be_administrator_automatically') }</small>
  29. </p>
  30. <form role="form" action="/installer/createAdmin" method="post" id="register-form">
  31. <div className={'input-group' + hasErrorClass}>
  32. <span className="input-group-addon"><i className="icon-user" /></span>
  33. <input type="text" className="form-control" placeholder={ this.props.t('User ID') }
  34. name="registerForm[username]" defaultValue={this.props.userName} onBlur={this.checkUserName} required />
  35. </div>
  36. <p className="help-block">{ unavailableUserId }</p>
  37. <div className="input-group">
  38. <span className="input-group-addon"><i className="icon-tag" /></span>
  39. <input type="text" className="form-control" placeholder={ this.props.t('Name') }
  40. name="registerForm[name]" defaultValue={ this.props.name } required />
  41. </div>
  42. <div className="input-group">
  43. <span className="input-group-addon"><i className="icon-envelope" /></span>
  44. <input type="email" className="form-control" placeholder={ this.props.t('Email') }
  45. name="registerForm[email]" defaultValue={ this.props.email } required />
  46. </div>
  47. <div className="input-group">
  48. <span className="input-group-addon"><i className="icon-lock" /></span>
  49. <input type="password" className="form-control" placeholder={ this.props.t('Password') }
  50. name="registerForm[password]" required />
  51. </div>
  52. <input type="hidden" name="_csrf" value={ this.props.csrf } />
  53. <div className="input-group m-t-20 m-b-20 mx-auto">
  54. <div className="radio radio-primary radio-inline">
  55. <input type="radio" id="radioLangEn" name="registerForm[app:globalLang]" value="en-US"
  56. defaultChecked={ true } onClick={() => this.changeLanguage('en-US')} />
  57. <label htmlFor="radioLangEn">{ this.props.t('English') }</label>
  58. </div>
  59. <div className="radio radio-primary radio-inline">
  60. <input type="radio" id="radioLangJa" name="registerForm[app:globalLang]" value="ja"
  61. defaultChecked={ false } onClick={() => this.changeLanguage('ja')} />
  62. <label htmlFor="radioLangJa">{ this.props.t('Japanese') }</label>
  63. </div>
  64. </div>
  65. <div className="input-group m-t-30 m-b-20 d-flex justify-content-center">
  66. <button type="submit" className="fcbtn btn btn-success btn-1b btn-register">
  67. <span className="btn-label"><i className="icon-user-follow" /></span>
  68. { this.props.t('Create') }
  69. </button>
  70. </div>
  71. <div className="input-group m-t-30 d-flex justify-content-center">
  72. <a href="https://growi.org" className="link-growi-org">
  73. <span className="growi">GROWI</span>.<span className="org">ORG</span>
  74. </a>
  75. </div>
  76. </form>
  77. </div>
  78. );
  79. }
  80. }
  81. InstallerForm.propTypes = {
  82. // i18next
  83. t: PropTypes.func.isRequired,
  84. // for input value
  85. userName: PropTypes.string,
  86. name: PropTypes.string,
  87. email: PropTypes.string,
  88. csrf: PropTypes.string,
  89. };
  90. export default translate()(InstallerForm);