AdminHome.jsx 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. import React, { Fragment } from 'react';
  2. import PropTypes from 'prop-types';
  3. import { withTranslation } from 'react-i18next';
  4. import { CopyToClipboard } from 'react-copy-to-clipboard';
  5. import loggerFactory from '~/utils/logger';
  6. import { toastError } from '~/client/util/apiNotification';
  7. import { withUnstatedContainers } from '../../UnstatedUtils';
  8. import AppContainer from '~/client/services/AppContainer';
  9. import AdminHomeContainer from '~/client/services/AdminHomeContainer';
  10. import SystemInfomationTable from './SystemInfomationTable';
  11. import InstalledPluginTable from './InstalledPluginTable';
  12. import EnvVarsTable from './EnvVarsTable';
  13. const logger = loggerFactory('growi:admin');
  14. class AdminHome extends React.Component {
  15. async componentDidMount() {
  16. const { adminHomeContainer } = this.props;
  17. try {
  18. await adminHomeContainer.retrieveAdminHomeData();
  19. }
  20. catch (err) {
  21. toastError(err);
  22. adminHomeContainer.setState({ retrieveError: err });
  23. logger.error(err);
  24. }
  25. }
  26. render() {
  27. const { t, adminHomeContainer } = this.props;
  28. return (
  29. <Fragment>
  30. <p>
  31. {t('admin:admin_top.wiki_administrator')}
  32. <br></br>
  33. {t('admin:admin_top.assign_administrator')}
  34. </p>
  35. <div className="row mb-5">
  36. <div className="col-lg-12">
  37. <h2 className="admin-setting-header">{t('admin:admin_top.system_information')}</h2>
  38. <SystemInfomationTable />
  39. </div>
  40. </div>
  41. <div className="row mb-5">
  42. <div className="col-lg-12">
  43. <h2 className="admin-setting-header">{t('admin:admin_top.list_of_installed_plugins')}</h2>
  44. <InstalledPluginTable />
  45. </div>
  46. </div>
  47. <div className="row mb-5">
  48. <div className="col-md-12">
  49. <h2 className="admin-setting-header">{t('admin:admin_top.list_of_env_vars')}</h2>
  50. <p>{t('admin:admin_top.env_var_priority')}</p>
  51. {/* eslint-disable-next-line react/no-danger */}
  52. <p dangerouslySetInnerHTML={{ __html: t('admin:admin_top.about_security') }} />
  53. {adminHomeContainer.state.envVars && <EnvVarsTable envVars={adminHomeContainer.state.envVars} />}
  54. </div>
  55. </div>
  56. <div className="row mb-5">
  57. <div className="col-md-12">
  58. <h2 className="admin-setting-header">{t('admin:admin_top.bug_report')}</h2>
  59. <p>
  60. <CopyToClipboard
  61. text={adminHomeContainer.generatePrefilledHostInformationMarkdown()}
  62. onCopy={() => adminHomeContainer.onCopyPrefilledHostInformation()}
  63. >
  64. <button type="button" className="btn btn-primary">
  65. {adminHomeContainer.state.copyState === adminHomeContainer.copyStateValues.DEFAULT
  66. ? t('admin:admin_top:copy_prefilled_host_information:default')
  67. : t('admin:admin_top:copy_prefilled_host_information:done')}
  68. </button>
  69. </CopyToClipboard>{' '}
  70. {/* eslint-disable-next-line react/no-danger */}
  71. <span dangerouslySetInnerHTML={{ __html: t('admin:admin_top:submit_bug_report') }} />
  72. </p>
  73. </div>
  74. </div>
  75. </Fragment>
  76. );
  77. }
  78. }
  79. const AdminHomeWrapper = withUnstatedContainers(AdminHome, [AppContainer, AdminHomeContainer]);
  80. AdminHome.propTypes = {
  81. t: PropTypes.func.isRequired, // i18next
  82. appContainer: PropTypes.instanceOf(AppContainer).isRequired,
  83. adminHomeContainer: PropTypes.instanceOf(AdminHomeContainer).isRequired,
  84. };
  85. export default withTranslation()(AdminHomeWrapper);