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, switchPageListLimitation: adminCustomizeContainer.switchPageListLimitationS, desc: 'admin:customize_setting.function_options.list_num_desc_s', dropdownMenu: [10, 30, 50], }, M: { label: 'admin:customize_setting.function_options.list_num_m', pageLimitation: adminCustomizeContainer.state.pageLimitationM, switchPageListLimitation: adminCustomizeContainer.switchPageListLimitationM, desc: 'admin:customize_setting.function_options.list_num_desc_m', dropdownMenu: [10, 30, 50], }, L: { label: 'admin:customize_setting.function_options.list_num_l', pageLimitation: adminCustomizeContainer.state.pageLimitationL, switchPageListLimitation: adminCustomizeContainer.switchPageListLimitationL, desc: 'admin:customize_setting.function_options.list_num_desc_l', dropdownMenu: [10, 30, 50], }, XL: { label: 'admin:customize_setting.function_options.list_num_xl', pageLimitation: adminCustomizeContainer.state.pageLimitationXL, switchPageListLimitation: adminCustomizeContainer.switchPageListLimitationXL, desc: 'admin:customize_setting.function_options.list_num_desc_xl', dropdownMenu: [10, 30, 50], }, }; 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 (
{value.pageLimitation} {value.dropdownMenu.map((v) => { return ( { value.switchPageListLimitation(v) }}> {v} ); })} {/* { value.switchPageListLimitation(30) }}> 30 { value.switchPageListLimitation(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);