From 27232b76378ce3f714c3ad4da5cb0b93e2b906b4 Mon Sep 17 00:00:00 2001 From: Braden MacDonald Date: Fri, 6 Sep 2024 11:57:05 -0700 Subject: [PATCH] feat: open the editor when creating a new component --- .../add-content/AddContentContainer.tsx | 15 ++++++++++++--- src/library-authoring/data/api.ts | 2 +- 2 files changed, 13 insertions(+), 4 deletions(-) diff --git a/src/library-authoring/add-content/AddContentContainer.tsx b/src/library-authoring/add-content/AddContentContainer.tsx index 421c81be68..f13023dac3 100644 --- a/src/library-authoring/add-content/AddContentContainer.tsx +++ b/src/library-authoring/add-content/AddContentContainer.tsx @@ -16,16 +16,19 @@ import { ContentPaste, } from '@openedx/paragon/icons'; import { v4 as uuid4 } from 'uuid'; -import { useParams } from 'react-router-dom'; +import { useNavigate, useParams } from 'react-router-dom'; + import { ToastContext } from '../../generic/toast-context'; import { useCopyToClipboard } from '../../generic/clipboard'; import { getCanEdit } from '../../course-unit/data/selectors'; import { useCreateLibraryBlock, useLibraryPasteClipboard } from '../data/apiHooks'; +import { getEditUrl } from '../components/utils'; import messages from './messages'; const AddContentContainer = () => { const intl = useIntl(); + const navigate = useNavigate(); const { libraryId } = useParams(); const createBlockMutation = useCreateLibraryBlock(); const pasteClipboardMutation = useLibraryPasteClipboard(); @@ -100,8 +103,14 @@ const AddContentContainer = () => { libraryId, blockType, definitionId: `${uuid4()}`, - }).then(() => { - showToast(intl.formatMessage(messages.successCreateMessage)); + }).then((data) => { + const editUrl = getEditUrl(data.id); + if (editUrl) { + navigate(editUrl); + } else { + // We can't start editing this right away so just show a toast message: + showToast(intl.formatMessage(messages.successCreateMessage)); + } }).catch(() => { showToast(intl.formatMessage(messages.errorCreateMessage)); }); diff --git a/src/library-authoring/data/api.ts b/src/library-authoring/data/api.ts index 78ed9f134b..5cde1e5de1 100644 --- a/src/library-authoring/data/api.ts +++ b/src/library-authoring/data/api.ts @@ -166,7 +166,7 @@ export async function createLibraryBlock({ definition_id: definitionId, }, ); - return data; + return camelCaseObject(data); } /**