From 6f1064479533d28d8a7761abbe3455b8eafc58b5 Mon Sep 17 00:00:00 2001 From: Niklas Reimer Date: Mon, 4 Mar 2024 15:53:08 +0100 Subject: [PATCH] implement evaluation --- .../medic/etl/openehrmapper/Generator.java | 36 +++++++++++-------- 1 file changed, 22 insertions(+), 14 deletions(-) diff --git a/src/main/java/de/uksh/medic/etl/openehrmapper/Generator.java b/src/main/java/de/uksh/medic/etl/openehrmapper/Generator.java index 8e43e07..3cd6619 100644 --- a/src/main/java/de/uksh/medic/etl/openehrmapper/Generator.java +++ b/src/main/java/de/uksh/medic/etl/openehrmapper/Generator.java @@ -166,27 +166,35 @@ public static void gen_OBSERVATION(String path, String name, Object jsonmap, Map processAttributeChildren(oap, paramName, history, (Map) map.get(paramName)); observation.setData(history); if (oa) { - ((ArrayList) jsonmap).add(observation); + ((List) jsonmap).add(observation); } } } + @SuppressWarnings("unchecked") public static void gen_EVALUATION(String path, String name, Object jsonmap, Map map) throws Exception { - String nodeId = getNodeId(path); - String label = getTypeLabel(path, nodeId); - // String newPath = path + "/attributes"; - Evaluation events = new Evaluation(); - events.setArchetypeNodeId(nodeId); + String paramName = getArcheTypeId(path); + String oap = path + "/attributes[rm_attribute_name=\"data\"]"; + Boolean oa = (Boolean) XP.evaluate(oap, opt, XPathConstants.BOOLEAN); - events.setNameAsString(label); + Evaluation evaluation = new Evaluation(); + evaluation.setArchetypeDetails(new Archetyped(new ArchetypeID(paramName), "1.1.0")); + evaluation.setArchetypeNodeId(paramName); + evaluation.setNameAsString(getLabel(getNodeId(path), paramName)); + evaluation.setLanguage(new CodePhrase(new TerminologyId("ISO_639-1"), "de")); + evaluation.setEncoding(new CodePhrase(new TerminologyId("IANA_character-sets"), "UTF-8")); + evaluation.setSubject(new PartySelf()); - // events.setTime(new DvDateTime((String) map.get("events_time"))); - // ItemTree itemTree = new ItemTree(); - // processAttributeChildren(path, nodeId, itemTree, map); - // events.setData(itemTree); + if (map.containsKey(paramName)) { + ItemTree data = new ItemTree(); + processAttributeChildren(oap, paramName, data, (Map) map.get(paramName)); + evaluation.setData(data); + if (oa) { + ((List) jsonmap).add(evaluation); + } + } - // ((History) jsonmap).addEvent(events); } @SuppressWarnings("unchecked") @@ -390,7 +398,7 @@ public static void gen_HISTORY(String path, String name, Object jsonmap, Map) map.get("events_time")).get(0))); processAttributeChildren(newPath, nodeId, history, map); } @@ -406,7 +414,7 @@ public static void gen_EVENT(String path, String name, Object jsonmap, Map) map.get("events_time")).get(0))); ItemTree itemTree = new ItemTree(); processAttributeChildren(newPath, nodeId, itemTree, map); events.setData(itemTree);