1
0
mirror of https://github.com/pcvolkmer/onkostar-plugin-dnpm.git synced 2025-07-02 01:02:55 +00:00

Plugin für FollowUp Formulare hinzugefügt

Das entsprechende Plugin ergänzt nun nach Auswahl der zugehörigen
Einzelempfehlung die Prozedur/das Formular der Einzelempfehlung
um einen Rückverweis auf das FollowUp.
This commit is contained in:
2023-03-10 15:27:46 +01:00
parent f90e4ec986
commit e89b31532b
2 changed files with 118 additions and 1 deletions

View File

@ -0,0 +1,116 @@
package DNPM.forms;
import de.itc.onkostar.api.Disease;
import de.itc.onkostar.api.IOnkostarApi;
import de.itc.onkostar.api.Item;
import de.itc.onkostar.api.Procedure;
import de.itc.onkostar.api.analysis.AnalyseTriggerEvent;
import de.itc.onkostar.api.analysis.AnalyzerRequirement;
import de.itc.onkostar.api.analysis.IProcedureAnalyzer;
import de.itc.onkostar.api.analysis.OnkostarPluginType;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import java.util.Set;
/**
* Diese Klasse implementiert ein Plugin, welches Aktionen nach Bearbeitung eines FollowUps durchführt.
*
* @since 0.0.2
*/
@Component
public class FollowUpAnalyzer implements IProcedureAnalyzer {
private final Logger logger = LoggerFactory.getLogger(this.getClass());
private final IOnkostarApi onkostarApi;
public FollowUpAnalyzer(IOnkostarApi onkostarApi) {
this.onkostarApi = onkostarApi;
}
@Override
public OnkostarPluginType getType() {
return OnkostarPluginType.ANALYZER;
}
@Override
public String getVersion() {
return "0.1.0";
}
@Override
public String getName() {
return "DNPM FollowUp Analyzer";
}
@Override
public String getDescription() {
return "Aktualisiert verknüpfte Formulare nach Änderungen im FollowUp-Formular";
}
/**
* @deprecated
*/
@Override
public boolean isRelevantForDeletedProcedure() {
return false;
}
@Override
public boolean isRelevantForAnalyzer(Procedure procedure, Disease disease) {
return null != procedure && procedure.getFormName().equals("DNPM FollowUp");
}
@Override
public boolean isSynchronous() {
return false;
}
@Override
public AnalyzerRequirement getRequirement() {
return AnalyzerRequirement.PROCEDURE;
}
@Override
public Set<AnalyseTriggerEvent> getTriggerEvents() {
return Set.of(
AnalyseTriggerEvent.EDIT_SAVE,
AnalyseTriggerEvent.EDIT_LOCK,
AnalyseTriggerEvent.REORG
);
}
@Override
public void analyze(Procedure procedure, Disease disease) {
backlinkToEinzelempfehlung(procedure);
}
/**
* Verlinke aktuelles FollowUp in angegebener Einzelempfehlung
*
* @param procedure Das FollowUp
*/
private void backlinkToEinzelempfehlung(Procedure procedure) {
var referencedProcedureId = procedure.getValue("LinkTherapieempfehlung").getInt();
if (referencedProcedureId == 0) {
// Alles gut, es ist keine Einzelempfehlung angegeben
return;
}
var referencedProcedure = onkostarApi.getProcedure(referencedProcedureId);
if (null == referencedProcedure) {
logger.error("Referenzierte Einzelempfehlung wurde nicht gefunden: {}", referencedProcedureId);
return;
}
referencedProcedure.setValue("refdnpmfollowup", new Item("ref_dnpm_followup", procedure.getId()));
try {
onkostarApi.saveProcedure(referencedProcedure);
} catch (Exception e) {
logger.error("FollowUp konnte nicht mit Einzelempfehlung verknüpft werden", e);
}
}
}

View File

@ -14,7 +14,8 @@
<bean id="Merkmalskatalog" class="DNPM.Merkmalskatalog" />
<bean id="ConsentManager" class="DNPM.ConsentManager" />
<context:component-scan base-package="ATCCodes"/>
<context:component-scan base-package="ATCCodes" />
<context:component-scan base-package="DNPM.forms" />
<mvc:resources mapping="/app/lib/umr/**" location="classpath:/app/lib/umr/" />
</beans>