From f01ebbd4e28ef4377ca7e1a52e023aa5badcf272 Mon Sep 17 00:00:00 2001 From: adongare Date: Mon, 9 Dec 2024 09:16:04 -0500 Subject: [PATCH] MAT-7652 do not replace FHIR model if thats the only using model for QICore measure/library --- src/AceEditor/madie-ace-editor.tsx | 19 ++++++++++--------- 1 file changed, 10 insertions(+), 9 deletions(-) diff --git a/src/AceEditor/madie-ace-editor.tsx b/src/AceEditor/madie-ace-editor.tsx index e570a9b..f91e8ec 100644 --- a/src/AceEditor/madie-ace-editor.tsx +++ b/src/AceEditor/madie-ace-editor.tsx @@ -86,21 +86,22 @@ export const updateUsingStatements = ( let isCqlUpdated = false; if (usingStatements?.length === 1) { const { name, version, start } = usingStatements[0]; - if ( - measureModel !== name || - modelVersion !== version.replace(/["']/g, "") - ) { - // we want to keep FHIR if that's the only using model present for QICore. + const cleanedVersion = version.replace(/["']/g, ""); + if (measureModel !== name || modelVersion !== cleanedVersion) { + // keep FHIR if that's the only using model present for QICore but update version if it was incorrect. if (measureModel === "QICore" && name === "FHIR") { - parsedEditorCqlCopy.cqlArrayToBeFiltered[ - start.line - 1 - ] = `using FHIR version '4.0.1'`; + if (cleanedVersion !== "4.0.1") { + parsedEditorCqlCopy.cqlArrayToBeFiltered[ + start.line - 1 + ] = `using FHIR version '4.0.1'`; + isCqlUpdated = true; + } } else { parsedEditorCqlCopy.cqlArrayToBeFiltered[ start.line - 1 ] = `using ${measureModel} version '${modelVersion}'`; + isCqlUpdated = true; } - isCqlUpdated = true; } } else if (usingStatements?.length > 1) { // to track if the usings statement was verified or not