AppSettingsPage.jsx 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. import React from 'react';
  2. import PropTypes from 'prop-types';
  3. import loggerFactory from '@alias/logger';
  4. import { withUnstatedContainers } from '../../UnstatedUtils';
  5. import { toastError } from '../../../util/apiNotification';
  6. import toArrayIfNot from '../../../../../lib/util/toArrayIfNot';
  7. import { withLoadingSppiner } from '../../SuspenseUtils';
  8. import AdminAppContainer from '../../../services/AdminAppContainer';
  9. import AppSettingsPageContents from './AppSettingsPageContents';
  10. const logger = loggerFactory('growi:appSettings');
  11. let retrieveErrors = null;
  12. function AppSettingsPage(props) {
  13. if (props.adminAppContainer.state.title === props.adminAppContainer.dummyTitle) {
  14. throw (async() => {
  15. try {
  16. await props.adminAppContainer.retrieveAppSettingsData();
  17. }
  18. catch (err) {
  19. const errs = toArrayIfNot(err);
  20. toastError(errs);
  21. logger.error(errs);
  22. props.adminAppContainer.setState({
  23. title: props.adminAppContainer.dummyTitleForError,
  24. });
  25. retrieveErrors = errs;
  26. }
  27. })();
  28. }
  29. if (props.adminAppContainer.state.title === props.adminAppContainer.dummyTitleForError) {
  30. throw new Error(`${retrieveErrors.length} errors occured`);
  31. }
  32. return <AppSettingsPageContents />;
  33. }
  34. AppSettingsPage.propTypes = {
  35. adminAppContainer: PropTypes.instanceOf(AdminAppContainer).isRequired,
  36. };
  37. /**
  38. * Wrapper component for using unstated
  39. */
  40. const AppSettingsPageWithUnstatedContainer = withUnstatedContainers(withLoadingSppiner(AppSettingsPage), [AdminAppContainer]);
  41. export default AppSettingsPageWithUnstatedContainer;