import React from 'react'; import PropTypes from 'prop-types'; import { withTranslation } from 'react-i18next'; import { Card, CardBody, UncontrolledDropdown, DropdownToggle, DropdownMenu, DropdownItem, } from 'reactstrap'; import { withUnstatedContainers } from '../../UnstatedUtils'; import { toastSuccess, toastError } from '../../../util/apiNotification'; import AppContainer from '../../../services/AppContainer'; import AdminCustomizeContainer from '../../../services/AdminCustomizeContainer'; import AdminUpdateButtonRow from '../Common/AdminUpdateButtonRow'; import CustomizeFunctionOption from './CustomizeFunctionOption'; class CustomizeFunctionSetting extends React.Component { constructor(props) { super(props); this.state = { }; this.onClickSubmit = this.onClickSubmit.bind(this); } async onClickSubmit() { const { t, adminCustomizeContainer } = this.props; try { await adminCustomizeContainer.updateCustomizeFunction(); toastSuccess(t('toaster.update_successed', { target: t('admin:customize_setting.function') })); } catch (err) { toastError(err); } } render() { const { t, adminCustomizeContainer } = this.props; const dropdownGroupMapping = { S: { label: 'admin:customize_setting.function_options.list_num_s', // pageLimitation: adminCustomizeContainer.state.pageLimitationS, // switchPageListLimitationS: adminCustomizeContainer.switchPageListLimitationS, desc: 'admin:customize_setting.function_options.list_num_desc_s', }, M: { label: 'admin:customize_setting.function_options.list_num_m', // pageLimitation: adminCustomizeContainer.state.pageLimitationM, // switchPageListLimitationS: adminCustomizeContainer.switchPageListLimitationM, desc: 'admin:customize_setting.function_options.list_num_desc_m', }, L: { label: 'admin:customize_setting.function_options.list_num_l', // pageLimitation: adminCustomizeContainer.state.pageLimitationL, // switchPageListLimitationS: adminCustomizeContainer.switchPageListLimitationL, desc: 'admin:customize_setting.function_options.list_num_desc_l', }, XL: { label: 'admin:customize_setting.function_options.list_num_xl', // pageLimitation: adminCustomizeContainer.state.pageLimitationXL, // switchPageListLimitationS: adminCustomizeContainer.switchPageListLimitation, desc: 'admin:customize_setting.function_options.list_num_desc_xl', }, }; return (

{t('admin:customize_setting.function')}

{t('admin:customize_setting.function_desc')}
{ adminCustomizeContainer.switchSavedStatesOfTabChanges() }} >

{t('admin:customize_setting.function_options.tab_switch_desc1')}
{t('admin:customize_setting.function_options.tab_switch_desc2')}

{ adminCustomizeContainer.switchEnabledAttachTitleHeader() }} >

{t('admin:customize_setting.function_options.attach_title_header_desc')}

{Object.entries(dropdownGroupMapping).map(([key, value]) => { return (
{/* */}
{adminCustomizeContainer.state.pageLimitationS} { adminCustomizeContainer.switchPageListLimitationS(10) }}> 10 { adminCustomizeContainer.switchPageListLimitationS(30) }}> 30 { adminCustomizeContainer.switchPageListLimitationS(50) }}> 50

{/* {t(value.desc)} */}

); })} {/* S: Modal */} {/*
{adminCustomizeContainer.state.pageLimitationS} { adminCustomizeContainer.switchPageListLimitationS(10) }}> 10 { adminCustomizeContainer.switchPageListLimitationS(30) }}> 30 { adminCustomizeContainer.switchPageListLimitationS(50) }}> 50

{t('admin:customize_setting.function_options.list_num_desc_s')}

*/} {/* M: User Page */} {/*
{adminCustomizeContainer.state.pageLimitationM} { adminCustomizeContainer.switchPageListLimitationM(10) }}> 10 { adminCustomizeContainer.switchPageListLimitationM(30) }}> 30 { adminCustomizeContainer.switchPageListLimitationM(50) }}> 50

{t('admin:customize_setting.function_options.list_num_desc_m')}

*/} {/* L: Search / Draft Pages */} {/*
{adminCustomizeContainer.state.pageLimitationL} { adminCustomizeContainer.switchPageListLimitationL(10) }}> 10 { adminCustomizeContainer.switchPageListLimitationL(30) }}> 30 { adminCustomizeContainer.switchPageListLimitationL(50) }}> 50

{t('admin:customize_setting.function_options.list_num_desc_l')}

*/} {/* XL: NotFound / Trash Pages */} {/*
{adminCustomizeContainer.state.pageLimitationXL} { adminCustomizeContainer.switchPageListLimitationXL(10) }}> 10 { adminCustomizeContainer.switchPageListLimitationXL(30) }}> 30 { adminCustomizeContainer.switchPageListLimitationXL(50) }}> 50

{t('admin:customize_setting.function_options.list_num_desc_xl')}

*/}
{ adminCustomizeContainer.switchEnableStaleNotification() }} >

{t('admin:customize_setting.function_options.stale_notification_desc')}

{ adminCustomizeContainer.switchIsAllReplyShown() }} >

{t('admin:customize_setting.function_options.show_all_reply_comments_desc')}

); } } const CustomizeFunctionSettingWrapper = withUnstatedContainers(CustomizeFunctionSetting, [AppContainer, AdminCustomizeContainer]); CustomizeFunctionSetting.propTypes = { t: PropTypes.func.isRequired, // i18next appContainer: PropTypes.instanceOf(AppContainer).isRequired, adminCustomizeContainer: PropTypes.instanceOf(AdminCustomizeContainer).isRequired, }; export default withTranslation()(CustomizeFunctionSettingWrapper);