diff options
author | vlad <vlad@driver.xyz> | 2017-06-27 17:13:02 -0700 |
---|---|---|
committer | vlad <vlad@driver.xyz> | 2017-06-27 17:13:02 -0700 |
commit | 5832f63b84d7388441d1200f2442dc1e9de0225c (patch) | |
tree | 32f63acdc920c14effc3d0d2822c05c125ad49e4 /src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPatientCriterion.scala | |
parent | 9dd50590d4c8f8b9442d7c21ddd1def9dd453d5e (diff) | |
download | rest-query-5832f63b84d7388441d1200f2442dc1e9de0225c.tar.gz rest-query-5832f63b84d7388441d1200f2442dc1e9de0225c.tar.bz2 rest-query-5832f63b84d7388441d1200f2442dc1e9de0225c.zip |
All PDS UI domain models, API case classes, service traits and necessary utils moved to pdsui-commonv0.1.11
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPatientCriterion.scala')
-rw-r--r-- | src/main/scala/xyz/driver/pdsuidomain/formats/json/patient/trial/ApiPatientCriterion.scala | 72 |
1 files changed, 72 insertions, 0 deletions
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")) + ) +} |