aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial')
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPartialPatientCriterion.scala40
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPartialPatientCriterionList.scala32
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPatientCriterion.scala72
3 files changed, 144 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPartialPatientCriterion.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPartialPatientCriterion.scala
new file mode 100644
index 0000000..b68dad5
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPartialPatientCriterion.scala
@@ -0,0 +1,40 @@
+package xyz.driver.pdsuidomain.formats.json.patient.trial
+
+import xyz.driver.pdsuidomain.entities.PatientCriterion
+import org.davidbild.tristate.Tristate
+import org.davidbild.tristate.contrib.play.ToJsPathOpsFromJsPath
+import play.api.data.validation.ValidationError
+import play.api.libs.functional.syntax._
+import play.api.libs.json.{Format, JsPath, Reads, Writes}
+import xyz.driver.pdsuicommon.domain.FuzzyValue
+
+final case class ApiPartialPatientCriterion(eligibilityStatus: Option[String],
+ verifiedEligibilityStatus: Tristate[String]) {
+
+ def applyTo(orig: PatientCriterion): PatientCriterion = {
+ orig.copy(
+ eligibilityStatus = eligibilityStatus.map(FuzzyValue.fromString).orElse(orig.eligibilityStatus),
+ verifiedEligibilityStatus = verifiedEligibilityStatus.cata(x =>
+ Some(FuzzyValue.fromString(x)),
+ None,
+ orig.verifiedEligibilityStatus
+ )
+ )
+ }
+}
+
+object ApiPartialPatientCriterion {
+
+ implicit val format: Format[ApiPartialPatientCriterion] = (
+ (JsPath \ "eligibilityStatus").formatNullable[String](Format(
+ Reads.of[String].filter(ValidationError("unknown eligibility status"))({
+ case x if FuzzyValue.fromString.isDefinedAt(x) => true
+ case _ => false
+ }), Writes.of[String])) and
+ (JsPath \ "verifiedEligibilityStatus").formatTristate[String](Format(
+ Reads.of[String].filter(ValidationError("unknown verified eligibility status"))({
+ case x if FuzzyValue.fromString.isDefinedAt(x) => true
+ case _ => false
+ }), Writes.of[String]))
+ ) (ApiPartialPatientCriterion.apply, unlift(ApiPartialPatientCriterion.unapply))
+}
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPartialPatientCriterionList.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPartialPatientCriterionList.scala
new file mode 100644
index 0000000..71cb58f
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPartialPatientCriterionList.scala
@@ -0,0 +1,32 @@
+package xyz.driver.pdsuidomain.formats.json.patient.trial
+
+import xyz.driver.pdsuicommon.domain.{FuzzyValue, LongId}
+import xyz.driver.pdsuidomain.entities.PatientCriterion
+import play.api.data.validation.ValidationError
+import play.api.libs.functional.syntax._
+import play.api.libs.json.{Format, JsPath, Reads, Writes}
+import xyz.driver.pdsuidomain.services.PatientCriterionService.DraftPatientCriterion
+
+final case class ApiPartialPatientCriterionList(id: Long,
+ eligibilityStatus: Option[String],
+ isVerified: Option[Boolean]) {
+
+ def toDomain: DraftPatientCriterion = DraftPatientCriterion(
+ id = LongId[PatientCriterion](id),
+ eligibilityStatus = eligibilityStatus.map(FuzzyValue.fromString),
+ isVerified = isVerified
+ )
+}
+
+object ApiPartialPatientCriterionList {
+
+ implicit val format: Format[ApiPartialPatientCriterionList] = (
+ (JsPath \ "id").format[Long] and
+ (JsPath \ "eligibilityStatus").formatNullable[String](Format(
+ Reads.of[String].filter(ValidationError("unknown eligibility status"))({
+ case x if FuzzyValue.fromString.isDefinedAt(x) => true
+ case _ => false
+ }), Writes.of[String])) and
+ (JsPath \ "isVerified").formatNullable[Boolean]
+ ) (ApiPartialPatientCriterionList.apply, unlift(ApiPartialPatientCriterionList.unapply))
+}
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPatientCriterion.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPatientCriterion.scala
new file mode 100644
index 0000000..3e2de99
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPatientCriterion.scala
@@ -0,0 +1,72 @@
+package xyz.driver.pdsuidomain.formats.json.patient.trial
+
+import java.time.{ZoneId, ZonedDateTime}
+
+import xyz.driver.pdsuicommon.domain.{FuzzyValue, LongId}
+import xyz.driver.pdsuidomain.entities.{Arm, Label, PatientCriterion}
+import play.api.data.validation.ValidationError
+import play.api.libs.functional.syntax._
+import play.api.libs.json.{Format, JsPath, Reads, Writes}
+
+final case class ApiPatientCriterion(id: Long,
+ labelId: Long,
+ nctId: String,
+ criterionText: String,
+ criterionValue: Option[String],
+ criterionIsDefining: Boolean,
+ criterionIsCompound: Boolean,
+ arms: List[String],
+ eligibilityStatus: Option[String],
+ verifiedEligibilityStatus: Option[String],
+ isVerified: Boolean,
+ isVisible: Boolean,
+ lastUpdate: ZonedDateTime)
+
+object ApiPatientCriterion {
+
+ implicit val format: Format[ApiPatientCriterion] = (
+ (JsPath \ "id").format[Long] and
+ (JsPath \ "labelId").format[Long] and
+ (JsPath \ "nctId").format[String] and
+ (JsPath \ "criterionText").format[String] and
+ (JsPath \ "criterionValue").formatNullable[String](Format(Reads.of[String].filter(ValidationError("unknown value"))({ x =>
+ x == "Yes" || x == "No"
+ }), Writes.of[String])) and
+ (JsPath \ "criterionIsDefining").format[Boolean] and
+ (JsPath \ "criterionIsCompound").format[Boolean] and
+ (JsPath \ "arms").format[List[String]] and
+ (JsPath \ "eligibilityStatus").formatNullable[String](Format(Reads.of[String].filter(ValidationError("unknown status"))({
+ case x if FuzzyValue.fromString.isDefinedAt(x) => true
+ case _ => false
+ }), Writes.of[String])) and
+ (JsPath \ "verifiedEligibilityStatus").formatNullable[String](Format(
+ Reads.of[String].filter(ValidationError("unknown status"))({
+ case x if FuzzyValue.fromString.isDefinedAt(x) => true
+ case _ => false
+ }), Writes.of[String])) and
+ (JsPath \ "isVerified").format[Boolean] and
+ (JsPath \ "isVisible").format[Boolean] and
+ (JsPath \ "lastUpdate").format[ZonedDateTime]
+ ) (ApiPatientCriterion.apply, unlift(ApiPatientCriterion.unapply))
+
+ def fromDomain(patientCriterion: PatientCriterion,
+ labelId: LongId[Label],
+ arms: List[Arm],
+ criterionIsCompound: Boolean) = ApiPatientCriterion(
+ id = patientCriterion.id.id,
+ labelId = labelId.id,
+ nctId = patientCriterion.nctId.id,
+ criterionText = patientCriterion.criterionText,
+ criterionValue = patientCriterion.criterionValue.map { x =>
+ FuzzyValue.valueToString(FuzzyValue.fromBoolean(x))
+ },
+ criterionIsDefining = patientCriterion.criterionIsDefining,
+ criterionIsCompound = criterionIsCompound,
+ arms = arms.map(_.name),
+ eligibilityStatus = patientCriterion.eligibilityStatus.map(FuzzyValue.valueToString),
+ verifiedEligibilityStatus = patientCriterion.verifiedEligibilityStatus.map(FuzzyValue.valueToString),
+ isVerified = patientCriterion.isVerified,
+ isVisible = patientCriterion.isVisible,
+ lastUpdate = ZonedDateTime.of(patientCriterion.lastUpdate, ZoneId.of("Z"))
+ )
+}