import React, { useCallback } from 'react'; import { useTranslation, i18n } from 'next-i18next'; import PropTypes from 'prop-types'; import { i18n as i18nConfig } from '^/config/next-i18next.config'; import AdminAppContainer from '~/client/services/AdminAppContainer'; import { toastSuccess, toastError } from '~/client/util/toastr'; 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(['admin', 'commons']); const submitHandler = useCallback(async() => { try { await adminAppContainer.updateAppSettingHandler(); toastSuccess(t('commons:toaster.update_successed', { target: t('commons:headers.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')}

{ i18nConfig.locales.map((locale) => { if (i18n == null) { return } const fixedT = i18n.getFixedT(locale, 'admin'); return (
{ adminAppContainer.changeGlobalLang(e.target.value); }} />
); }) }
{ adminAppContainer.changeIsEmailPublishedForNewUserShow(true) }} />
{ adminAppContainer.changeIsEmailPublishedForNewUserShow(false) }} />
{ adminAppContainer.changeFileUpload(e.target.checked); }} />

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

{ adminAppContainer.changeIsPageBulkExportEnabled(e.target.checked); }} />

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

{adminAppContainer.state.isFixedIsBulkExportPagesEnabled && (

help FIXED
{/* eslint-disable-next-line react/no-danger */}

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