InstallerForm.jsx 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  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. componentWillMount() {
  14. this.changeLanguage('en-US');
  15. }
  16. checkUserName(event) {
  17. const axios = require('axios').create({
  18. headers: {
  19. 'Content-Type': 'application/json',
  20. 'X-Requested-With': 'XMLHttpRequest'
  21. },
  22. responseType: 'json'
  23. });
  24. axios.get('/_api/check_username', {params: {username: event.target.value}})
  25. .then((res) => this.setState({ isValidUserName: res.data.valid }));
  26. }
  27. changeLanguage(locale) {
  28. i18next.changeLanguage(locale);
  29. }
  30. render() {
  31. const hasErrorClass = this.state.isValidUserName ? '' : ' has-error';
  32. const unavailableUserId = this.state.isValidUserName ? '' : <span><i className="icon-fw icon-ban" />{ this.props.t('installer.unavaliable_user_id') }</span>;
  33. return (
  34. <div className={'login-dialog p-t-10 p-b-10 col-sm-offset-4 col-sm-4' + hasErrorClass}>
  35. <p className="alert alert-success">
  36. <strong>{ this.props.t('installer.create_initial_account') }</strong><br />
  37. <small>{ this.props.t('installer.initial_account_will_be_administrator_automatically') }</small>
  38. </p>
  39. <form role="form" action="/installer" method="post" id="register-form">
  40. <div className="input-group m-t-20 m-b-20 mx-auto">
  41. <div className="radio radio-primary radio-inline">
  42. <input type="radio" id="radioLangEn" name="registerForm[app:globalLang]" value="en-US"
  43. defaultChecked={ true } onClick={() => this.changeLanguage('en-US')} />
  44. <label htmlFor="radioLangEn">English</label>
  45. </div>
  46. <div className="radio radio-primary radio-inline">
  47. <input type="radio" id="radioLangJa" name="registerForm[app:globalLang]" value="ja"
  48. defaultChecked={ false } onClick={() => this.changeLanguage('ja')} />
  49. <label htmlFor="radioLangJa">日本語</label>
  50. </div>
  51. </div>
  52. <div className={'input-group' + hasErrorClass}>
  53. <span className="input-group-addon"><i className="icon-user" /></span>
  54. <input type="text" className="form-control" placeholder={ this.props.t('User ID') }
  55. name="registerForm[username]" defaultValue={this.props.userName} onBlur={this.checkUserName} required />
  56. </div>
  57. <p className="help-block">{ unavailableUserId }</p>
  58. <div className="input-group">
  59. <span className="input-group-addon"><i className="icon-tag" /></span>
  60. <input type="text" className="form-control" placeholder={ this.props.t('Name') }
  61. name="registerForm[name]" defaultValue={ this.props.name } required />
  62. </div>
  63. <div className="input-group">
  64. <span className="input-group-addon"><i className="icon-envelope" /></span>
  65. <input type="email" className="form-control" placeholder={ this.props.t('Email') }
  66. name="registerForm[email]" defaultValue={ this.props.email } required />
  67. </div>
  68. <div className="input-group">
  69. <span className="input-group-addon"><i className="icon-lock" /></span>
  70. <input type="password" className="form-control" placeholder={ this.props.t('Password') }
  71. name="registerForm[password]" required />
  72. </div>
  73. <input type="hidden" name="_csrf" value={ this.props.csrf } />
  74. <div className="input-group m-t-30 m-b-20 d-flex justify-content-center">
  75. <button type="submit" className="fcbtn btn btn-success btn-1b btn-register">
  76. <span className="btn-label"><i className="icon-user-follow" /></span>
  77. { this.props.t('Create') }
  78. </button>
  79. </div>
  80. <div className="input-group m-t-30 d-flex justify-content-center">
  81. <a href="https://growi.org" className="link-growi-org">
  82. <span className="growi">GROWI</span>.<span className="org">ORG</span>
  83. </a>
  84. </div>
  85. </form>
  86. </div>
  87. );
  88. }
  89. }
  90. InstallerForm.propTypes = {
  91. // i18next
  92. t: PropTypes.func.isRequired,
  93. // for input value
  94. userName: PropTypes.string,
  95. name: PropTypes.string,
  96. email: PropTypes.string,
  97. csrf: PropTypes.string,
  98. };
  99. export default translate()(InstallerForm);