diff options
author | Vlad Uspensky <v.uspenskiy@icloud.com> | 2017-07-28 12:27:48 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-07-28 12:27:48 -0700 |
commit | a1178df3e08759f85c9c891b17c5185df46f1a93 (patch) | |
tree | 06eef00bd8dfa5ecd7a1d207bac7f02a76caba79 /src/main/scala/xyz/driver/pdsuidomain/formats/json/recordissue | |
parent | 838c6a345c749a58472ee4324f60a3759a83aedd (diff) | |
parent | 54d0c6f7e7d7040e214cd2595a260bc65f356e33 (diff) | |
download | rest-query-a1178df3e08759f85c9c891b17c5185df46f1a93.tar.gz rest-query-a1178df3e08759f85c9c891b17c5185df46f1a93.tar.bz2 rest-query-a1178df3e08759f85c9c891b17c5185df46f1a93.zip |
PDSUI-2157 Create own messages table for Documents, Medical Records and Patients
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuidomain/formats/json/recordissue')
-rw-r--r-- | src/main/scala/xyz/driver/pdsuidomain/formats/json/recordissue/ApiPartialRecordIssue.scala | 52 | ||||
-rw-r--r-- | src/main/scala/xyz/driver/pdsuidomain/formats/json/recordissue/ApiRecordIssue.scala | 48 |
2 files changed, 100 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/recordissue/ApiPartialRecordIssue.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/recordissue/ApiPartialRecordIssue.scala new file mode 100644 index 0000000..07a88aa --- /dev/null +++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/recordissue/ApiPartialRecordIssue.scala @@ -0,0 +1,52 @@ +package xyz.driver.pdsuidomain.formats.json.recordissue + +import java.time.LocalDateTime + +import play.api.libs.functional.syntax._ +import play.api.libs.json._ +import xyz.driver.pdsuicommon.domain.{LongId, StringId, User} +import xyz.driver.pdsuidomain.entities.{MedicalRecord, MedicalRecordIssue} + +final case class ApiPartialRecordIssue(startPage: Option[Double], + endPage: Option[Double], + text: String, + evidence: String, + archiveRequired: Boolean, + meta: String) { + def applyTo(x: MedicalRecordIssue): MedicalRecordIssue = x.copy( + startPage = startPage, + endPage = endPage, + text = text, + evidence = evidence, + archiveRequired = archiveRequired, + meta = meta + ) + + def toDomain(userId: StringId[User], recordId: LongId[MedicalRecord]) = + MedicalRecordIssue( + id = LongId(0), + userId = userId, + recordId = recordId, + startPage = startPage, + endPage = endPage, + lastUpdate = LocalDateTime.MIN, + isDraft = true, + text = text, + evidence = evidence, + archiveRequired = false, + meta = meta + ) +} + +object ApiPartialRecordIssue { + implicit val format: Format[ApiPartialRecordIssue] = ( + (JsPath \ "startPage").formatNullable[Double] and + (JsPath \ "endPage").formatNullable[Double] and + (JsPath \ "text").format[String] and + (JsPath \ "evidence").format[String] and + (JsPath \ "archiveRequired").format[Boolean] and + (JsPath \ "meta").format[String](Format(Reads { x => + JsSuccess(Json.stringify(x)) + }, Writes[String](Json.parse))) + )(ApiPartialRecordIssue.apply, unlift(ApiPartialRecordIssue.unapply)) +} diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/recordissue/ApiRecordIssue.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/recordissue/ApiRecordIssue.scala new file mode 100644 index 0000000..adab72e --- /dev/null +++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/recordissue/ApiRecordIssue.scala @@ -0,0 +1,48 @@ +package xyz.driver.pdsuidomain.formats.json.recordissue + +import java.time.{ZoneId, ZonedDateTime} + +import play.api.libs.functional.syntax._ +import play.api.libs.json._ +import xyz.driver.pdsuidomain.entities.MedicalRecordIssue + +final case class ApiRecordIssue(id: Long, + startPage: Option[Double], + endPage: Option[Double], + text: String, + lastUpdate: ZonedDateTime, + userId: String, + isDraft: Boolean, + evidence: String, + archiveRequired: Boolean, + meta: String) + +object ApiRecordIssue { + implicit val format: Format[ApiRecordIssue] = ( + (JsPath \ "id").format[Long] and + (JsPath \ "startPage").formatNullable[Double] and + (JsPath \ "endPage").formatNullable[Double] and + (JsPath \ "text").format[String] and + (JsPath \ "lastUpdate").format[ZonedDateTime] and + (JsPath \ "userId").format[String] and + (JsPath \ "isDraft").format[Boolean] and + (JsPath \ "evidence").format[String] and + (JsPath \ "archiveRequired").format[Boolean] and + (JsPath \ "meta").format[String](Format(Reads { x => + JsSuccess(Json.stringify(x)) + }, Writes[String](Json.parse))) + )(ApiRecordIssue.apply, unlift(ApiRecordIssue.unapply)) + + def fromDomain(x: MedicalRecordIssue) = ApiRecordIssue( + id = x.id.id, + startPage = x.startPage, + endPage = x.endPage, + text = x.text, + lastUpdate = ZonedDateTime.of(x.lastUpdate, ZoneId.of("Z")), + userId = x.userId.id, + isDraft = x.isDraft, + evidence = x.evidence, + archiveRequired = x.archiveRequired, + meta = x.meta + ) +} |