From 18ae518d1a03bc5f1b2d7f0baf7b20dd98bbd140 Mon Sep 17 00:00:00 2001 From: Novak Zaballa Date: Wed, 5 Jun 2024 16:18:36 -0400 Subject: [PATCH] Solve the issue of creating a Metadata field without entities --- .../components/modals/CreateMetadataField.tsx | 135 ++++++++++-------- .../pages/EnvironmentSettingsPage.js | 1 - 2 files changed, 79 insertions(+), 57 deletions(-) diff --git a/frontend/web/components/modals/CreateMetadataField.tsx b/frontend/web/components/modals/CreateMetadataField.tsx index 0c694ff42d24..e6cb2981b24a 100644 --- a/frontend/web/components/modals/CreateMetadataField.tsx +++ b/frontend/web/components/modals/CreateMetadataField.tsx @@ -24,6 +24,7 @@ import { MetadataModelField, isRequiredFor, } from 'common/types/responses' +import ErrorMessage from 'components/ErrorMessage' type CreateMetadataFieldType = { id?: string @@ -76,8 +77,10 @@ const CreateMetadataField: FC = ({ const { data: supportedContentTypes } = useGetSupportedContentTypeQuery({ organisation_id: `${organisationId}`, }) - const [createMetadataField, { isLoading: creating, isSuccess: created }] = - useCreateMetadataFieldMutation() + const [ + createMetadataField, + { error: errorCreating, isLoading: creating, isSuccess: created }, + ] = useCreateMetadataFieldMutation() const [updateMetadataField, { isLoading: updating, isSuccess: updated }] = useUpdateMetadataFieldMutation() @@ -167,31 +170,47 @@ const CreateMetadataField: FC = ({ }, id: id!, }).then(() => { - Promise.all( - metadataUpdatedSelectList?.map( - async (m: metadataFieldUpdatedSelectListType) => { + if (metadataFieldSelectList.length) { + Promise.all( + metadataFieldSelectList.map(async (m) => { const query = generateDataQuery( - m.content_type, - m.field, - m.is_required_for, - m.id, - m.new, + m.value, + parseInt(id!), + !!m?.isRequired, + 0, + true, ) - if (!m.removed && !m.new) { - await updateMetadataModelField(query) - } else if (m.removed) { - await deleteMetadataModelField({ - id: m.id, - organisation_id: organisationId, - }) - } else if (m.new) { - const newQuery = { ...query } - delete newQuery.id - await createMetadataModelField(newQuery) - } - }, - ), - ) + await createMetadataModelField(query) + }), + ) + } + if (metadataUpdatedSelectList.length) { + Promise.all( + metadataUpdatedSelectList?.map( + async (m: metadataFieldUpdatedSelectListType) => { + const query = generateDataQuery( + m.content_type, + m.field, + m.is_required_for, + m.id, + m.new, + ) + if (!m.removed && !m.new) { + await updateMetadataModelField(query) + } else if (m.removed) { + await deleteMetadataModelField({ + id: m.id, + organisation_id: organisationId, + }) + } else if (m.new) { + const newQuery = { ...query } + delete newQuery.id + await createMetadataModelField(newQuery) + } + }, + ), + ) + } closeModal() }) } else { @@ -272,50 +291,54 @@ const CreateMetadataField: FC = ({ if (isEdit) { const newMetadataFieldArray: metadataFieldUpdatedSelectListType[] = [] + if (!metadataModelFieldList?.length) { + setMetadataFieldSelectList(m) + } else { + metadataModelFieldList?.forEach((item1) => { + const match = m.find( + (item2) => item2.value === item1.content_type.toString(), + ) - metadataModelFieldList?.forEach((item1) => { - const match = m.find( - (item2) => item2.value === item1.content_type.toString(), - ) - - if (match) { - const isRequiredLength = !!item1.is_required_for.length - const isRequired = match.isRequired - if (isRequiredLength !== isRequired) { + if (match) { + const isRequiredLength = !!item1.is_required_for.length + const isRequired = match.isRequired + if (isRequiredLength !== isRequired) { + newMetadataFieldArray.push({ + ...item1, + is_required_for: isRequired, + }) + } + } else { newMetadataFieldArray.push({ ...item1, - is_required_for: isRequired, + new: false, + removed: true, }) } - } else { - newMetadataFieldArray.push({ - ...item1, - new: false, - removed: true, + m.forEach((item) => { + const match = metadataModelFieldList.find( + (item2) => item2.content_type.toString() === item.value, + ) + if (!match) { + newMetadataFieldArray.push({ + ...item1, + content_type: item.value, + is_required_for: m?.isRequired, + new: true, + removed: false, + }) + } }) - } - m.forEach((item) => { - const match = metadataModelFieldList.find( - (item2) => item2.content_type.toString() === item.value, - ) - if (!match) { - newMetadataFieldArray.push({ - ...item1, - content_type: item.value, - is_required_for: m?.isRequired, - new: true, - removed: false, - }) - } }) - }) - setMetadataFieldUpdatedSelectList(newMetadataFieldArray) + setMetadataFieldUpdatedSelectList(newMetadataFieldArray) + } } else { setMetadataFieldSelectList(m) } }} metadataModelFieldList={metadataModelFieldList!} /> + {errorCreating && }