From f9a11092a61f7b705b835741d95b12bbcfe9b243 Mon Sep 17 00:00:00 2001 From: Amruth Pillai Date: Thu, 27 Jul 2023 18:35:19 +0200 Subject: [PATCH] Fix issue when a section is duplicated/cloned, ID is null --- client/templates/sectionMap.tsx | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/client/templates/sectionMap.tsx b/client/templates/sectionMap.tsx index facbd4792..039d6f0e2 100644 --- a/client/templates/sectionMap.tsx +++ b/client/templates/sectionMap.tsx @@ -44,11 +44,11 @@ const sectionMap = (Section: React.FC): Record, }); -export const getSectionById = (id: string, Section: React.FC): JSX.Element => { - // Check if section id is a custom section (an uuid) - if (validate(id)) { - return
; - } +export const getSectionById = (id: string, Section: React.FC): JSX.Element | null => { + if (!id) return null; + + // Check if section id is a custom section (is a valid uuid) + if (validate(id)) return
; // Check if section id is a predefined seciton in config const predefinedSection = get(sectionMap(Section), id); @@ -57,9 +57,11 @@ export const getSectionById = (id: string, Section: React.FC): JSX return predefinedSection; } - // Other ways section should be a cloned section - const section = find(sectionMap(Section), (element, key) => id.includes(key)); - return React.cloneElement(section!, { path: `sections.${id}` }); + // Otherwise, section must be a cloned section + const section = find(sectionMap(Section), (_element, key) => id.includes(key)); + if (section) return React.cloneElement(section, { path: `sections.${id}` }); + + return null; }; export default sectionMap;