From b25e9e6774b437ca4cc96f842d7982743ad00f70 Mon Sep 17 00:00:00 2001 From: 0einstein0 Date: Fri, 28 Jun 2024 17:41:22 +0200 Subject: [PATCH] subcommunity: updated fieldpaths and error handling --- .../invenio_communities/subcommunity/new.js | 32 ++++++++++--------- 1 file changed, 17 insertions(+), 15 deletions(-) diff --git a/invenio_communities/assets/semantic-ui/js/invenio_communities/subcommunity/new.js b/invenio_communities/assets/semantic-ui/js/invenio_communities/subcommunity/new.js index f6d3e2ba3..4dfdc7dc4 100644 --- a/invenio_communities/assets/semantic-ui/js/invenio_communities/subcommunity/new.js +++ b/invenio_communities/assets/semantic-ui/js/invenio_communities/subcommunity/new.js @@ -42,15 +42,15 @@ const IdentifierField = ({ formConfig }) => { return ( } - fieldPath="community.slug" + fieldPath="metadata.slug" helpText={helpText} fluid className="text-muted" @@ -84,7 +84,7 @@ class CommunityCreateForm extends Component { .filter((item) => !item?.parent?.id) .filter((item) => !item?.children?.allow === true) .map((item) => ({ - text: item.community.title, + text: item.metadata.title, value: item.id, key: item.id, })), @@ -112,12 +112,12 @@ class CommunityCreateForm extends Component { let payload = {}; let slug = ""; if (hasCommunity) { - payload = { community_id: values["community"]["community"] }; + payload = { community_id: values["metadata"]["community"] }; } else { - slug = values["community"]["slug"]; + slug = values["metadata"]["slug"]; payload = { community: { - title: values["community"]["title"], + title: values["metadata"]["title"], slug: slug, }, }; @@ -139,7 +139,9 @@ class CommunityCreateForm extends Component { const { errors, message } = communityErrorSerializer(error); if (message) { - this.setGlobalError("The form contains errors or missing fields. Please verify before submitting"); + this.setGlobalError( + "The form contains errors or missing fields. Please verify before submitting" + ); } if (errors) { @@ -147,7 +149,7 @@ class CommunityCreateForm extends Component { // Check if the field is already prefixed with "metadata" if (!field.startsWith("metadata")) { // Add "metadata" prefix if not already present - field = `metadata.${field.split('.').pop()}`; + field = `metadata.${field.split(".").pop()}`; } setFieldError(field, messages[0]); }); @@ -212,7 +214,7 @@ class CommunityCreateForm extends Component { onChange={() => { this.setState({ hasCommunity: true }); }} - fieldPath="community.hasCommunity" + fieldPath="metadata.hasCommunity" /> { this.setState({ hasCommunity: false }); }} - fieldPath="community.hasCommunity" + fieldPath="metadata.hasCommunity" /> @@ -235,7 +237,7 @@ class CommunityCreateForm extends Component { class="block" /> } - fieldPath="community.community" + fieldPath="metadata.community" options={communities} defaultValue="Loading..." required @@ -246,16 +248,16 @@ class CommunityCreateForm extends Component { <> { e.key === "Enter" && e.preventDefault(); }} label={