diff --git a/odd-platform-ui/src/components/Terms/TermSearch/TermForm/TermsForm.tsx b/odd-platform-ui/src/components/Terms/TermSearch/TermForm/TermsForm.tsx index 7404ed249..c8ed77662 100644 --- a/odd-platform-ui/src/components/Terms/TermSearch/TermForm/TermsForm.tsx +++ b/odd-platform-ui/src/components/Terms/TermSearch/TermForm/TermsForm.tsx @@ -80,18 +80,23 @@ const TermsForm: FC = ({ btnCreateEl }) => { }; const onSubmit = (data: TermFormData) => { - const duplicateTerm = existingTerms.find( - (existingTerm: TermDetails) => - existingTerm.name === data.name && - existingTerm.namespace.name === data.namespaceName - ); - - if (duplicateTerm) { - setError('A term with the same name already exists in this namespace.'); - return; + // Check if we're in create mode (no term.id present) + if (!term?.id) { + const duplicateTerm = existingTerms.find( + (existingTerm: TermDetails) => + existingTerm.name === data.name && + existingTerm.namespace.name === data.namespaceName + ); + + if (duplicateTerm) { + setError('A term with the same name already exists in this namespace.'); + return; + } } const parsedData = { ...data }; + + // Determine whether to create or update the term (term && term.id ? dispatch(updateTerm({ termId: term.id, termFormData: parsedData })) : dispatch(createTerm({ termFormData: parsedData })) @@ -210,4 +215,4 @@ const TermsForm: FC = ({ btnCreateEl }) => { ); }; -export default TermsForm; +export default TermsForm; \ No newline at end of file