From db48c45aa790a870a725dfcfa705bad1af1de9f3 Mon Sep 17 00:00:00 2001 From: Zvonimir Fras Date: Thu, 19 Oct 2023 18:36:33 -0400 Subject: [PATCH] Display handlebars compile error & prevent saving Signed-off-by: Zvonimir Fras --- src/components/custom-components-modal.tsx | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/src/components/custom-components-modal.tsx b/src/components/custom-components-modal.tsx index 362f1165e..4dcebe3ab 100644 --- a/src/components/custom-components-modal.tsx +++ b/src/components/custom-components-modal.tsx @@ -1,6 +1,7 @@ import React, { useContext, useState } from 'react'; import { Modal } from '@carbon/react'; import Editor from '@monaco-editor/react'; +import Handlebars from 'handlebars'; import { GlobalStateContext, ModalContext } from '../context'; export const CustomComponentsModal = () => { @@ -14,7 +15,16 @@ export const CustomComponentsModal = () => { try { if (modelString) { // TODO set exact modelCollection based on name instead - setCustomComponentsCollections([JSON.parse(modelString)]); + const parsedModel = JSON.parse(modelString); + parsedModel.components.forEach((component: any, index: number) => { + // try parsing template to check for compile errors + try { + (Handlebars.compile(component.htmlPreview))((component.defaultInputs)); + } catch (e) { + throw new Error(`Component ${index} [${component?.type}] htmlPreview` + e); + } + }); + setCustomComponentsCollections([parsedModel]); } setJsonParseError('');