aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/hypothesis
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/hypothesis')
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/hypothesis/ApiPartialPatientHypothesis.scala27
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/hypothesis/ApiPatientHypothesis.scala32
2 files changed, 59 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/hypothesis/ApiPartialPatientHypothesis.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/hypothesis/ApiPartialPatientHypothesis.scala
new file mode 100644
index 0000000..0858ce1
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/hypothesis/ApiPartialPatientHypothesis.scala
@@ -0,0 +1,27 @@
+package xyz.driver.pdsuidomain.formats.json.patient.hypothesis
+
+import xyz.driver.pdsuidomain.entities.PatientHypothesis
+import org.davidbild.tristate.Tristate
+import org.davidbild.tristate.contrib.play.ToJsPathOpsFromJsPath
+import play.api.libs.functional.syntax._
+import play.api.libs.json._
+
+final case class ApiPartialPatientHypothesis(rationale: Tristate[String]) {
+
+ def applyTo(orig: PatientHypothesis): PatientHypothesis = {
+ orig.copy(
+ rationale = rationale.cata(Some(_), None, orig.rationale)
+ )
+ }
+}
+
+object ApiPartialPatientHypothesis {
+
+ implicit val reads: Reads[ApiPartialPatientHypothesis] =
+ (__ \ "rationale").readTristate[String].map(x => ApiPartialPatientHypothesis(x))
+
+ implicit val writes: Writes[ApiPartialPatientHypothesis] =
+ (__ \ "rationale").writeTristate[String].contramap(_.rationale)
+
+ implicit val format: Format[ApiPartialPatientHypothesis] = Format(reads, writes)
+}
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/hypothesis/ApiPatientHypothesis.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/hypothesis/ApiPatientHypothesis.scala
new file mode 100644
index 0000000..1b0767d
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/hypothesis/ApiPatientHypothesis.scala
@@ -0,0 +1,32 @@
+package xyz.driver.pdsuidomain.formats.json.patient.hypothesis
+
+import java.util.UUID
+
+import xyz.driver.pdsuidomain.entities.PatientHypothesis
+import play.api.libs.functional.syntax._
+import play.api.libs.json._
+
+final case class ApiPatientHypothesis(id: UUID,
+ patientId: String,
+ hypothesisId: UUID,
+ matchedTrials: Long,
+ rationale: Option[String])
+
+object ApiPatientHypothesis {
+
+ implicit val apiPatientHypothesisJsonFormat: Format[ApiPatientHypothesis] = (
+ (JsPath \ "id").format[UUID] and
+ (JsPath \ "patientId").format[String] and
+ (JsPath \ "hypothesisId").format[UUID] and
+ (JsPath \ "matchedTrials").format[Long] and
+ (JsPath \ "rationale").formatNullable[String]
+ ) (ApiPatientHypothesis.apply, unlift(ApiPatientHypothesis.unapply))
+
+ def fromDomain(patientHypothesis: PatientHypothesis) = ApiPatientHypothesis(
+ id = patientHypothesis.id.id,
+ patientId = patientHypothesis.patientId.toString,
+ hypothesisId = patientHypothesis.hypothesisId.id,
+ matchedTrials = patientHypothesis.matchedTrials,
+ rationale = patientHypothesis.rationale
+ )
+}