From 3f6bc8888ed774a3f8efab57763b98418e8cd179 Mon Sep 17 00:00:00 2001 From: Johnson Mao <86179381+JohnsonMao@users.noreply.github.com> Date: Sun, 17 Nov 2024 10:48:35 +0800 Subject: [PATCH 1/3] feat(group): optimize area checkbox selection logic --- components/Group/Form/Fields/AreaCheckbox.jsx | 35 +++++++++++++------ .../Group/Form/Fields/CheckboxGroup.jsx | 4 +-- components/Group/Form/Fields/Select.jsx | 3 +- components/Group/Form/Fields/TextField.jsx | 3 +- components/Group/Form/index.jsx | 2 +- components/Group/Form/useGroupForm.jsx | 8 ++--- 6 files changed, 35 insertions(+), 20 deletions(-) diff --git a/components/Group/Form/Fields/AreaCheckbox.jsx b/components/Group/Form/Fields/AreaCheckbox.jsx index f82f1b4e..f2c320c2 100644 --- a/components/Group/Form/Fields/AreaCheckbox.jsx +++ b/components/Group/Form/Fields/AreaCheckbox.jsx @@ -17,29 +17,46 @@ export default function AreaCheckbox({ const getPhysicalArea = (data) => options.find((option) => data.includes(option.name)); - const handleChange = (val) => - control.onChange({ target: { name, value: val } }); + const handleChange = (val, action, _value) => { + if (action === 'add' && _value === '待討論') { + control.onChange({ target: { name, value: ['待討論'] } }); + setIsPhysicalArea(false); + return; + } + if (action === 'remove' && !val.length) { + control.onChange({ target: { name, value: ['待討論'] } }); + setIsPhysicalArea(false); + return; + } + control.onChange({ target: { name, value: val.filter((v) => v !== '待討論') } }); + }; const physicalAreaValue = getPhysicalArea(value)?.name || ''; const toggleIsPhysicalArea = () => { const updatedValue = value.filter((v) => !getPhysicalArea([v])); - handleChange(updatedValue); - setIsPhysicalArea((pre) => !pre); + if (isPhysicalArea && updatedValue.includes('待討論')) { + handleChange(updatedValue, 'add', '待討論'); + } else { + handleChange(updatedValue); + setIsPhysicalArea((pre) => !pre); + } }; const handleCheckboxChange = (_value) => { - const updatedValue = value.includes(_value) + const hasValue = value.includes(_value); + const action = hasValue ? 'remove' : 'add'; + const updatedValue = hasValue ? value.filter((v) => v !== _value) : [...value, _value]; - handleChange(updatedValue); + handleChange(updatedValue, action, _value); }; const handlePhysicalAreaChange = ({ target }) => { const updatedValue = value .filter((v) => !getPhysicalArea([v])) .concat(target.value); - handleChange(updatedValue); + handleChange(updatedValue, 'add', target.value); }; const physicalAreaControl = { @@ -57,14 +74,12 @@ export default function AreaCheckbox({ } label="實體活動" - disabled={value.includes('待討論')} checked={isPhysicalArea} />