summaryrefslogtreecommitdiff
path: root/src/main/java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java')
-rw-r--r--src/main/java/DNPM/services/mtb/DefaultMtbService.java39
-rw-r--r--src/main/java/DNPM/services/mtb/MtbService.java9
-rw-r--r--src/main/java/DNPM/services/mtb/OsTumorkonferenzToProtocolMapper.java33
-rw-r--r--src/main/java/DNPM/services/mtb/OsTumorkonferenzVarianteUkwToProtocolMapper.java42
-rw-r--r--src/main/java/DNPM/services/mtb/ProcedureToProtocolMapper.java10
5 files changed, 133 insertions, 0 deletions
diff --git a/src/main/java/DNPM/services/mtb/DefaultMtbService.java b/src/main/java/DNPM/services/mtb/DefaultMtbService.java
new file mode 100644
index 0000000..40d9360
--- /dev/null
+++ b/src/main/java/DNPM/services/mtb/DefaultMtbService.java
@@ -0,0 +1,39 @@
+package DNPM.services.mtb;
+
+import DNPM.services.SettingsService;
+import de.itc.onkostar.api.Procedure;
+
+import java.util.List;
+
+public class DefaultMtbService implements MtbService {
+
+ private final SettingsService settingsService;
+
+ public DefaultMtbService(final SettingsService settingsService) {
+ this.settingsService = settingsService;
+ }
+
+ @Override
+ public String getProtocol(List<Procedure> procedures) {
+ ProcedureToProtocolMapper mapper = null;
+ var sid = settingsService.getSID();
+
+ if (sid.isPresent()) {
+ switch (sid.get()) {
+ case "20119":
+ mapper = new OsTumorkonferenzVarianteUkwToProtocolMapper();
+ default:
+ if (!settingsService.multipleMtbsInMtbEpisode()) {
+ mapper = new OsTumorkonferenzToProtocolMapper();
+ }
+ }
+ }
+
+ if (null == mapper) {
+ return "";
+ }
+
+ return mapper.apply(procedures).orElse("");
+ }
+
+}
diff --git a/src/main/java/DNPM/services/mtb/MtbService.java b/src/main/java/DNPM/services/mtb/MtbService.java
new file mode 100644
index 0000000..b854307
--- /dev/null
+++ b/src/main/java/DNPM/services/mtb/MtbService.java
@@ -0,0 +1,9 @@
+package DNPM.services.mtb;
+
+import de.itc.onkostar.api.Procedure;
+
+import java.util.List;
+
+public interface MtbService {
+ String getProtocol(List<Procedure> procedures);
+}
diff --git a/src/main/java/DNPM/services/mtb/OsTumorkonferenzToProtocolMapper.java b/src/main/java/DNPM/services/mtb/OsTumorkonferenzToProtocolMapper.java
new file mode 100644
index 0000000..f6684a2
--- /dev/null
+++ b/src/main/java/DNPM/services/mtb/OsTumorkonferenzToProtocolMapper.java
@@ -0,0 +1,33 @@
+package DNPM.services.mtb;
+
+import de.itc.onkostar.api.Procedure;
+
+import java.util.List;
+import java.util.Optional;
+
+public class OsTumorkonferenzToProtocolMapper implements ProcedureToProtocolMapper {
+ @Override
+ public Optional<String> apply(List<Procedure> procedures) {
+ assert(procedures.size() == 1);
+
+ var procedure = procedures.get(0);
+
+ assert(procedure.getFormName().equals("OS.Tumorkonferenz"));
+
+ var fragestellung = procedure.getValue("Fragestellung");
+ var empfehlung = procedure.getValue("Empfehlung");
+
+ if (
+ null != fragestellung && !fragestellung.getString().isBlank()
+ && null != empfehlung && !empfehlung.getString().isBlank()
+ ) {
+ return Optional.of(String.format("%s\n%s", fragestellung.getString(), empfehlung.getString()));
+ } else if (null != fragestellung && !fragestellung.getString().isBlank()) {
+ return Optional.of(fragestellung.getString());
+ } else if (null != empfehlung && !empfehlung.getString().isBlank()) {
+ return Optional.of(empfehlung.getString());
+ }
+
+ return Optional.empty();
+ }
+}
diff --git a/src/main/java/DNPM/services/mtb/OsTumorkonferenzVarianteUkwToProtocolMapper.java b/src/main/java/DNPM/services/mtb/OsTumorkonferenzVarianteUkwToProtocolMapper.java
new file mode 100644
index 0000000..de36415
--- /dev/null
+++ b/src/main/java/DNPM/services/mtb/OsTumorkonferenzVarianteUkwToProtocolMapper.java
@@ -0,0 +1,42 @@
+package DNPM.services.mtb;
+
+import de.itc.onkostar.api.Procedure;
+
+import java.util.Comparator;
+import java.util.List;
+import java.util.Optional;
+import java.util.stream.Collectors;
+
+public class OsTumorkonferenzVarianteUkwToProtocolMapper implements ProcedureToProtocolMapper {
+ @Override
+ public Optional<String> apply(List<Procedure> procedures) {
+ procedures.forEach(procedure -> {
+ assert (procedure.getFormName().equals("OS.Tumorkonferenz.VarianteUKW"));
+ });
+
+ procedures.sort(Comparator.comparing(Procedure::getStartDate));
+
+ var result = procedures.stream().map(procedure -> {
+ var fragestellung = procedure.getValue("Fragestellung");
+ var empfehlung = procedure.getValue("Empfehlung");
+
+ if (
+ null != fragestellung && !fragestellung.getString().isBlank()
+ && null != empfehlung && !empfehlung.getString().isBlank()
+ ) {
+ return String.format("%s\n%s", fragestellung.getString(), empfehlung.getString());
+ } else if (null != fragestellung && !fragestellung.getString().isBlank()) {
+ return fragestellung.getString();
+ } else if (null != empfehlung && !empfehlung.getString().isBlank()) {
+ return empfehlung.getString();
+ }
+ return "";
+ }).collect(Collectors.joining("\n"));
+
+ if (!result.isBlank()) {
+ return Optional.of(result);
+ }
+
+ return Optional.empty();
+ }
+}
diff --git a/src/main/java/DNPM/services/mtb/ProcedureToProtocolMapper.java b/src/main/java/DNPM/services/mtb/ProcedureToProtocolMapper.java
new file mode 100644
index 0000000..54c04d9
--- /dev/null
+++ b/src/main/java/DNPM/services/mtb/ProcedureToProtocolMapper.java
@@ -0,0 +1,10 @@
+package DNPM.services.mtb;
+
+import de.itc.onkostar.api.Procedure;
+
+import java.util.List;
+import java.util.Optional;
+import java.util.function.Function;
+
+@FunctionalInterface
+public interface ProcedureToProtocolMapper extends Function<List<Procedure>, Optional<String>> {}