import React, { useCallback } from 'react'; import PropTypes from 'prop-types'; import { useTranslation } from 'react-i18next'; import AdminAppContainer from '~/client/services/AdminAppContainer'; import { toastSuccess, toastError } from '~/client/util/apiNotification'; import { localeMetadatas } from '~/client/util/i18n'; import loggerFactory from '~/utils/logger'; import { withUnstatedContainers } from '../../UnstatedUtils'; import AdminUpdateButtonRow from '../Common/AdminUpdateButtonRow'; const logger = loggerFactory('growi:appSettings'); const AppSetting = (props) => { const { adminAppContainer } = props; const { t } = useTranslation(); const submitHandler = useCallback(async() => { try { await adminAppContainer.updateAppSettingHandler(); toastSuccess(t('toaster.update_successed', { target: t('App Settings') })); } catch (err) { toastError(err); logger.error(err); } }, [adminAppContainer, t]); return (
{ adminAppContainer.changeTitle(e.target.value); }} placeholder="GROWI" />

{t('admin:app_setting.sitename_change')}

{ adminAppContainer.changeConfidential(e.target.value); }} placeholder={t('admin:app_setting.confidential_example')} />

{t('admin:app_setting.header_content')}

{ localeMetadatas.map(meta => (
{ adminAppContainer.changeGlobalLang(e.target.value); }} />
)) }
{ adminAppContainer.changeIsEmailPublishedForNewUserShow(true) }} />
{ adminAppContainer.changeIsEmailPublishedForNewUserShow(false) }} />
{ adminAppContainer.changeFileUpload(e.target.checked); }} />

{t('admin:app_setting.attach_enable')}

); }; /** * Wrapper component for using unstated */ const AppSettingWrapper = withUnstatedContainers(AppSetting, [AdminAppContainer]); AppSetting.propTypes = { adminAppContainer: PropTypes.instanceOf(AdminAppContainer).isRequired, }; export default AppSettingWrapper;