1
0
mirror of https://github.com/pcvolkmer/mv64e-onkostar-data.git synced 2025-07-02 02:22:54 +00:00

feat: add display and system to patient data

This commit is contained in:
2025-06-22 12:01:38 +02:00
parent a10842df0c
commit 21739a055d
5 changed files with 75 additions and 24 deletions

View File

@ -60,7 +60,7 @@ public class PropertyCatalogue {
private final String shortdesc;
private final String description;
Entry(String code, String shortdesc, String description) {
public Entry(String code, String shortdesc, String description) {
this.code = code;
this.shortdesc = shortdesc;
this.description = description;

View File

@ -1,6 +1,7 @@
package dev.pcvolkmer.onco.datamapper.mapper;
import dev.pcvolkmer.mv64e.mtb.*;
import dev.pcvolkmer.onco.datamapper.PropertyCatalogue;
import dev.pcvolkmer.onco.datamapper.ResultSet;
import dev.pcvolkmer.onco.datamapper.datacatalogues.KpaCatalogue;
@ -13,9 +14,14 @@ import dev.pcvolkmer.onco.datamapper.datacatalogues.KpaCatalogue;
public class KpaPatientDataMapper implements DataMapper<Patient> {
private final KpaCatalogue kpaCatalogue;
private final PropertyCatalogue propertyCatalogue;
public KpaPatientDataMapper(final KpaCatalogue kpaCatalogue) {
public KpaPatientDataMapper(
final KpaCatalogue kpaCatalogue,
final PropertyCatalogue propertyCatalogue
) {
this.kpaCatalogue = kpaCatalogue;
this.propertyCatalogue = propertyCatalogue;
}
/**
@ -40,30 +46,36 @@ public class KpaPatientDataMapper implements DataMapper<Patient> {
}
private GenderCoding getGenderCoding(ResultSet data) {
var genderCodingBuilder = GenderCoding.builder();
var genderCodingBuilder = GenderCoding.builder()
.system("Gender");
String geschlecht = data.getString("geschlecht");
switch (geschlecht) {
case "m":
genderCodingBuilder.code(GenderCodingCode.MALE);
genderCodingBuilder.code(GenderCodingCode.MALE).display("Männlich");
break;
case "w":
genderCodingBuilder.code(GenderCodingCode.FEMALE);
genderCodingBuilder.code(GenderCodingCode.FEMALE).display("Weiblich");
break;
case "d":
case "x":
genderCodingBuilder.code(GenderCodingCode.OTHER);
genderCodingBuilder.code(GenderCodingCode.OTHER).display("Divers");
break;
default:
genderCodingBuilder.code(GenderCodingCode.UNKNOWN);
genderCodingBuilder.code(GenderCodingCode.UNKNOWN).display("Unbekannt");
}
return genderCodingBuilder.build();
}
private HealthInsurance getHealthInsurance(ResultSet data) {
var healthInsuranceCodingBuilder = HealthInsuranceCoding.builder();
var healthInsuranceCodingBuilder = HealthInsuranceCoding.builder()
.system("http://fhir.de/CodeSystem/versicherungsart-de-basis");
String healthInsuranceType = data.getString("artderkrankenkasse");
if (healthInsuranceType == null) {
healthInsuranceCodingBuilder.code(HealthInsuranceCodingCode.UNK).build();
healthInsuranceCodingBuilder
.code(HealthInsuranceCodingCode.UNK)
.build();
return HealthInsurance.builder().type(healthInsuranceCodingBuilder.build()).build();
}
@ -99,6 +111,13 @@ public class KpaPatientDataMapper implements DataMapper<Patient> {
healthInsuranceCodingBuilder.code(HealthInsuranceCodingCode.UNK).build();
}
var healthInsurancePropertyEntry = propertyCatalogue.getByCodeAndVersion(
data.getString("artderkrankenkasse"),
data.getInteger("artderkrankenkasse_propcat_version")
);
healthInsuranceCodingBuilder.display(healthInsurancePropertyEntry.getDescription());
return HealthInsurance.builder().type(healthInsuranceCodingBuilder.build()).build();
}

View File

@ -1,10 +1,8 @@
package dev.pcvolkmer.onco.datamapper.mapper;
import dev.pcvolkmer.mv64e.mtb.Mtb;
import dev.pcvolkmer.onco.datamapper.datacatalogues.DataCatalogueFactory;
import dev.pcvolkmer.onco.datamapper.datacatalogues.KpaCatalogue;
import dev.pcvolkmer.onco.datamapper.datacatalogues.PatientCatalogue;
import dev.pcvolkmer.onco.datamapper.datacatalogues.ProzedurCatalogue;
import dev.pcvolkmer.onco.datamapper.PropertyCatalogue;
import dev.pcvolkmer.onco.datamapper.datacatalogues.*;
import dev.pcvolkmer.onco.datamapper.exceptions.DataAccessException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@ -24,9 +22,11 @@ public class MtbDataMapper implements DataMapper<Mtb> {
private final Logger logger = LoggerFactory.getLogger(this.getClass());
private final DataCatalogueFactory catalogueFactory;
private final PropertyCatalogue propertyCatalogue;
MtbDataMapper(final JdbcTemplate jdbcTemplate) {
this.catalogueFactory = DataCatalogueFactory.initialize(jdbcTemplate);
this.propertyCatalogue = PropertyCatalogue.initialize(jdbcTemplate);
}
/**
@ -59,8 +59,12 @@ public class MtbDataMapper implements DataMapper<Mtb> {
public Mtb getById(int kpaId) {
var kpaCatalogue = catalogueFactory.catalogue(KpaCatalogue.class);
var patientDataMapper = new PatientDataMapper(catalogueFactory.catalogue(PatientCatalogue.class));
var kpaPatientDataMapper = new KpaPatientDataMapper(kpaCatalogue);
var diagnosisDataMapper = new KpaDiagnosisDataMapper(kpaCatalogue);
var kpaPatientDataMapper = new KpaPatientDataMapper(kpaCatalogue, propertyCatalogue);
var diagnosisDataMapper = new KpaDiagnosisDataMapper(
kpaCatalogue,
catalogueFactory.catalogue(TumorausbreitungCatalogue.class),
catalogueFactory.catalogue(TumorgradingCatalogue.class)
);
var prozedurMapper = new KpaProzedurDataMapper(catalogueFactory.catalogue(ProzedurCatalogue.class));
var resultBuilder = Mtb.builder();

View File

@ -43,20 +43,22 @@ public class PatientDataMapper implements DataMapper<Patient> {
}
private GenderCoding getGenderCoding(final ResultSet data) {
var genderCodingBuilder = GenderCoding.builder();
var genderCodingBuilder = GenderCoding.builder()
.system("Gender");
String geschlecht = data.getString("geschlecht");
switch (geschlecht) {
case "M":
genderCodingBuilder.code(GenderCodingCode.MALE);
genderCodingBuilder.code(GenderCodingCode.MALE).display("Männlich");
break;
case "F":
genderCodingBuilder.code(GenderCodingCode.FEMALE);
genderCodingBuilder.code(GenderCodingCode.FEMALE).display("Weiblich");
break;
case "X":
genderCodingBuilder.code(GenderCodingCode.OTHER);
genderCodingBuilder.code(GenderCodingCode.OTHER).display("Divers");
break;
default:
genderCodingBuilder.code(GenderCodingCode.UNKNOWN);
genderCodingBuilder.code(GenderCodingCode.UNKNOWN).display("Unbekannt");
}
return genderCodingBuilder.build();
}

View File

@ -1,6 +1,7 @@
package dev.pcvolkmer.onco.datamapper.mapper;
import dev.pcvolkmer.mv64e.mtb.*;
import dev.pcvolkmer.onco.datamapper.PropertyCatalogue;
import dev.pcvolkmer.onco.datamapper.ResultSet;
import dev.pcvolkmer.onco.datamapper.datacatalogues.KpaCatalogue;
import org.junit.jupiter.api.BeforeEach;
@ -23,13 +24,18 @@ import static org.mockito.Mockito.doAnswer;
class KpaPatientDataMapperTest {
KpaCatalogue kpaCatalogue;
PropertyCatalogue propertyCatalogue;
KpaPatientDataMapper dataMapper;
@BeforeEach
void setUp(@Mock KpaCatalogue kpaCatalogue) {
void setUp(
@Mock KpaCatalogue kpaCatalogue,
@Mock PropertyCatalogue propertyCatalogue
) {
this.kpaCatalogue = kpaCatalogue;
this.dataMapper = new KpaPatientDataMapper(kpaCatalogue);
this.propertyCatalogue = propertyCatalogue;
this.dataMapper = new KpaPatientDataMapper(kpaCatalogue, propertyCatalogue);
}
@Test
@ -61,6 +67,10 @@ class KpaPatientDataMapperTest {
.when(kpaCatalogue)
.getById(anyInt());
doAnswer(invocationOnMock ->
new PropertyCatalogue.Entry("GKV", "Gesetzliche Krankenversicherung", "Gesetzliche Krankenversicherung")
).when(propertyCatalogue).getByCodeAndVersion(anyString(), anyInt());
var actual = this.dataMapper.getById(1);
assertThat(actual).isInstanceOf(Patient.class);
assertThat(actual.getId()).isEqualTo("1");
@ -68,7 +78,13 @@ class KpaPatientDataMapperTest {
assertThat(actual.getBirthDate()).isEqualTo(Date.from(Instant.parse("2000-01-01T12:00:00Z")));
assertThat(actual.getDateOfDeath()).isEqualTo(Date.from(Instant.parse("2024-06-19T12:00:00Z")));
assertThat(actual.getHealthInsurance()).isEqualTo(
HealthInsurance.builder().type(HealthInsuranceCoding.builder().code(HealthInsuranceCodingCode.GKV).build()).build()
HealthInsurance.builder().type(
HealthInsuranceCoding.builder()
.code(HealthInsuranceCodingCode.GKV)
.display("Gesetzliche Krankenversicherung")
.system("http://fhir.de/CodeSystem/versicherungsart-de-basis")
.build()
).build()
);
}
@ -95,6 +111,10 @@ class KpaPatientDataMapperTest {
.when(kpaCatalogue)
.getById(anyInt());
doAnswer(invocationOnMock ->
new PropertyCatalogue.Entry("PKV", "Private Krankenversicherung", "Private Krankenversicherung")
).when(propertyCatalogue).getByCodeAndVersion(anyString(), anyInt());
var actual = this.dataMapper.getById(1);
assertThat(actual).isInstanceOf(Patient.class);
assertThat(actual.getId()).isEqualTo("1");
@ -102,7 +122,13 @@ class KpaPatientDataMapperTest {
assertThat(actual.getBirthDate()).isEqualTo(Date.from(Instant.parse("2000-01-01T12:00:00Z")));
assertThat(actual.getDateOfDeath()).isNull();
assertThat(actual.getHealthInsurance()).isEqualTo(
HealthInsurance.builder().type(HealthInsuranceCoding.builder().code(HealthInsuranceCodingCode.PKV).build()).build()
HealthInsurance.builder().type(
HealthInsuranceCoding.builder()
.code(HealthInsuranceCodingCode.PKV)
.display("Private Krankenversicherung")
.system("http://fhir.de/CodeSystem/versicherungsart-de-basis")
.build()
).build()
);
}