FullTextSearchManagement.jsx 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. import React, { Fragment } from 'react';
  2. import PropTypes from 'prop-types';
  3. import { withTranslation } from 'react-i18next';
  4. import { createSubscribedElement } from '../UnstatedUtils';
  5. import AppContainer from '../../services/AppContainer';
  6. import { toastSuccess, toastError } from '../../util/apiNotification';
  7. import AdminRebuildSearch from './AdminRebuildSearch';
  8. class FullTextSearchManagement extends React.Component {
  9. constructor(props) {
  10. super(props);
  11. this.buildIndex = this.buildIndex.bind(this);
  12. }
  13. async buildIndex() {
  14. const { appContainer } = this.props;
  15. const pageId = this.pageId;
  16. try {
  17. const res = await appContainer.apiPost('/admin/search/build', { page_id: pageId });
  18. if (!res.ok) {
  19. throw new Error(res.message);
  20. }
  21. else {
  22. toastSuccess('Building request is successfully posted.');
  23. }
  24. }
  25. catch (e) {
  26. toastError(e, (new Error('エラーが発生しました')));
  27. }
  28. }
  29. render() {
  30. const { t } = this.props;
  31. return (
  32. <Fragment>
  33. <fieldset>
  34. <legend> { t('full_text_search_management.elasticsearch_management') } </legend>
  35. <div className="form-group form-horizontal">
  36. <div className="col-xs-3 control-label"></div>
  37. <div className="col-xs-7">
  38. <button type="submit" className="btn btn-inverse" onClick={this.buildIndex}>{ t('full_text_search_management.build_button') }</button>
  39. <p className="help-block">
  40. { t('full_text_search_management.rebuild_description_1') }<br />
  41. { t('full_text_search_management.rebuild_description_2') }<br />
  42. { t('full_text_search_management.rebuild_description_3') }<br />
  43. </p>
  44. </div>
  45. </div>
  46. </fieldset>
  47. <AdminRebuildSearch />
  48. </Fragment>
  49. );
  50. }
  51. }
  52. const FullTextSearchManagementWrapper = (props) => {
  53. return createSubscribedElement(FullTextSearchManagement, props, [AppContainer]);
  54. };
  55. FullTextSearchManagement.propTypes = {
  56. t: PropTypes.func.isRequired, // i18next
  57. appContainer: PropTypes.instanceOf(AppContainer).isRequired,
  58. };
  59. export default withTranslation()(FullTextSearchManagementWrapper);