From f1dc86c2660293b87d8be996994f5eea61066d77 Mon Sep 17 00:00:00 2001 From: Janis Joderi Shoferi Date: Wed, 15 Nov 2023 13:28:56 +0100 Subject: [PATCH] Added some comments --- .../components/xml-editor.tsx | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/src/management-system-v2/components/xml-editor.tsx b/src/management-system-v2/components/xml-editor.tsx index 41471cd8e..eee600f69 100644 --- a/src/management-system-v2/components/xml-editor.tsx +++ b/src/management-system-v2/components/xml-editor.tsx @@ -24,7 +24,14 @@ type XmlEditorProps = { onSaveXml: (bpmn: string) => Promise; }; +/** + * Checks for syntax errors in the bpmn as well as for moddle warnings + * + * @param bpmn + * @returns found syntax errors or warnings + */ async function checkBpmn(bpmn: string) { + // check the bpmn (xml) for syntax errors using the domparser const domParser = new DOMParser(); var dom = domParser.parseFromString(bpmn, 'text/xml'); const parserErrors = dom.getElementsByTagName('parsererror'); @@ -34,6 +41,7 @@ async function checkBpmn(bpmn: string) { ); if (match) { + // convert the positional information into a format that can be passed to the monaco editor let [_, lineString, columnString, message] = match; const line = parseInt(lineString); const column = parseInt(columnString); @@ -49,8 +57,8 @@ async function checkBpmn(bpmn: string) { } } + // check for bpmn related mistakes (nonconformity with the underlying model [e.g. unknown elements or attributes]) const { warnings } = await moddle.fromXML(bpmn); - // TODO: how do we want to show which warnings exist to the user? return { warnings }; } @@ -75,6 +83,7 @@ const XmlEditor: FC = ({ bpmn, canSave, onClose, onSaveXml }) => async function validateProcess() { if (editorRef.current && monacoRef.current) { + // reset error markings in the editor monacoRef.current.editor.setModelMarkers(editorRef.current.getModel()!, 'owner', []); setSaveState('none'); const bpmn = editorRef.current.getValue(); @@ -83,6 +92,7 @@ const XmlEditor: FC = ({ bpmn, canSave, onClose, onSaveXml }) => if (error) { setSaveState('error'); + // add new error markings monacoRef.current.editor.setModelMarkers(editorRef.current.getModel()!, 'owner', [ { ...error, severity: monacoRef.current.MarkerSeverity.Error }, ]); @@ -127,7 +137,7 @@ const XmlEditor: FC = ({ bpmn, canSave, onClose, onSaveXml }) => const handleDownload = async () => { if (editorRef.current && isSuccess) { - let filename = process!.definitionName || 'process.bpmn'; + let filename = process!.definitionName || process!.definitionId || 'process'; if (selectedVersionId > -1) { const versionInfo = process?.versions.find(({ version }) => version == selectedVersionId); @@ -144,6 +154,7 @@ const XmlEditor: FC = ({ bpmn, canSave, onClose, onSaveXml }) => } }; + // display different information for the save button and handle its click differently based on the current state of the editor (error / warnings / no issues) const saveButton = { disabled: (