import { Typography } from 'antd'; import React, { useContext, useEffect, useState } from 'react'; import { TEXTFIELD_TYPE_TEXTAREA } from '../components/config/form-textfield'; import TextFieldWithSubmit from '../components/config/form-textfield-with-submit'; import ToggleSwitch from '../components/config/form-toggleswitch'; import { UpdateArgs } from '../types/config-section'; import { FIELD_PROPS_DISABLE_CHAT, TEXTFIELD_PROPS_CHAT_USERNAME_BLOCKLIST, } from '../utils/config-constants'; import { ServerStatusContext } from '../utils/server-status-context'; export default function ConfigChat() { const { Title } = Typography; const [formDataValues, setFormDataValues] = useState(null); const serverStatusData = useContext(ServerStatusContext); const { serverConfig } = serverStatusData || {}; const { chatDisabled } = serverConfig; const { usernameBlocklist } = serverConfig; const handleFieldChange = ({ fieldName, value }: UpdateArgs) => { setFormDataValues({ ...formDataValues, [fieldName]: value, }); }; function handleChatDisableChange(disabled: boolean) { handleFieldChange({ fieldName: 'chatDisabled', value: disabled }); } function handleChatUsernameBlockListChange(args: UpdateArgs) { handleFieldChange({ fieldName: 'usernameBlocklist', value: args.value }); } useEffect(() => { setFormDataValues({ chatDisabled, usernameBlocklist, }); }, [serverConfig]); if (!formDataValues) { return null; } return (