aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala
diff options
context:
space:
mode:
authorKseniya Tomskikh <ktomskih@datamonsters.co>2017-10-10 13:47:28 +0700
committerKseniya Tomskikh <ktomskih@datamonsters.co>2017-10-10 19:07:40 +0700
commitd93f220502fd2aa20a2b4bc4b5f1d58b4089bdad (patch)
treec3476e9bc76b62c28a084e770ebf2cee59e61b45 /src/main/scala
parent4f83461cba1f78e607ca2a4edb6fa26f6e16e732 (diff)
downloadrest-query-d93f220502fd2aa20a2b4bc4b5f1d58b4089bdad.tar.gz
rest-query-d93f220502fd2aa20a2b4bc4b5f1d58b4089bdad.tar.bz2
rest-query-d93f220502fd2aa20a2b4bc4b5f1d58b4089bdad.zip
PDSUI-2265 Added total_pages field to MedicalRecord
Diffstat (limited to 'src/main/scala')
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/entities/MedicalRecord.scala3
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/fakes/entities/rep/MedicalRecordGen.scala3
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/formats/json/record/ApiCreateRecord.scala3
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/formats/json/record/ApiRecord.scala12
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/formats/json/sprayformats/record.scala6
5 files changed, 18 insertions, 9 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/entities/MedicalRecord.scala b/src/main/scala/xyz/driver/pdsuidomain/entities/MedicalRecord.scala
index ed35db4..591b8bd 100644
--- a/src/main/scala/xyz/driver/pdsuidomain/entities/MedicalRecord.scala
+++ b/src/main/scala/xyz/driver/pdsuidomain/entities/MedicalRecord.scala
@@ -156,7 +156,8 @@ final case class MedicalRecord(id: LongId[MedicalRecord],
caseId: Option[CaseId],
physician: Option[String],
meta: Option[TextJson[List[Meta]]],
- lastUpdate: LocalDateTime) {
+ lastUpdate: LocalDateTime,
+ totalPages: Int) {
import MedicalRecord.Status._
diff --git a/src/main/scala/xyz/driver/pdsuidomain/fakes/entities/rep/MedicalRecordGen.scala b/src/main/scala/xyz/driver/pdsuidomain/fakes/entities/rep/MedicalRecordGen.scala
index 254968a..eb475b4 100644
--- a/src/main/scala/xyz/driver/pdsuidomain/fakes/entities/rep/MedicalRecordGen.scala
+++ b/src/main/scala/xyz/driver/pdsuidomain/fakes/entities/rep/MedicalRecordGen.scala
@@ -93,7 +93,8 @@ object MedicalRecordGen {
caseId = nextOption(CaseId(generators.nextString())),
physician = nextOption(generators.nextString()),
meta = nextOption(nextMedicalRecordMetasJson()),
- lastUpdate = nextLocalDateTime
+ lastUpdate = nextLocalDateTime,
+ totalPages = nextInt(1, 10)
)
}
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/record/ApiCreateRecord.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/record/ApiCreateRecord.scala
index 1f8c683..fd14f7c 100644
--- a/src/main/scala/xyz/driver/pdsuidomain/formats/json/record/ApiCreateRecord.scala
+++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/record/ApiCreateRecord.scala
@@ -22,7 +22,8 @@ final case class ApiCreateRecord(disease: String, patientId: String, requestId:
caseId = None,
physician = None,
meta = None,
- lastUpdate = LocalDateTime.now()
+ lastUpdate = LocalDateTime.now(),
+ totalPages = 0
)
}
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/record/ApiRecord.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/record/ApiRecord.scala
index fc0a2e7..00441a1 100644
--- a/src/main/scala/xyz/driver/pdsuidomain/formats/json/record/ApiRecord.scala
+++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/record/ApiRecord.scala
@@ -41,7 +41,8 @@ object ApiRecord {
(JsPath \ "requestId").format[UUID] and
(JsPath \ "meta").format(Format(Reads { x =>
JsSuccess(Json.stringify(x))
- }, Writes[String](Json.parse)))
+ }, Writes[String](Json.parse))) and
+ (JsPath \ "totalPages").format[Int]
)(ApiRecord.apply, unlift(ApiRecord.unapply))
def fromDomain(record: MedicalRecord) = ApiRecord(
@@ -57,7 +58,8 @@ object ApiRecord {
previousAssignee = record.previousAssignee.map(_.id),
lastActiveUser = record.lastActiveUserId.map(_.id),
requestId = record.requestId.id,
- meta = record.meta.map(x => JsonSerializer.serialize(x.content)).getOrElse(emptyMeta)
+ meta = record.meta.map(x => JsonSerializer.serialize(x.content)).getOrElse(emptyMeta),
+ totalPages = record.totalPages
)
}
@@ -73,7 +75,8 @@ final case class ApiRecord(id: Long,
previousAssignee: Option[String],
lastActiveUser: Option[String],
requestId: UUID,
- meta: String) {
+ meta: String,
+ totalPages: Int) {
private def extractStatus(status: String): Status =
Status
@@ -101,6 +104,7 @@ final case class ApiRecord(id: Long,
Some(TextJson(JsonSerializer.deserialize[List[MedicalRecord.Meta]](this.meta)))
}
},
- lastUpdate = this.lastUpdate.toLocalDateTime()
+ lastUpdate = this.lastUpdate.toLocalDateTime,
+ totalPages = 0
)
}
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/sprayformats/record.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/sprayformats/record.scala
index 65687c1..e8c0b94 100644
--- a/src/main/scala/xyz/driver/pdsuidomain/formats/json/sprayformats/record.scala
+++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/sprayformats/record.scala
@@ -172,7 +172,8 @@ object record {
"requestId" -> record.requestId.toJson,
"meta" -> record.meta.getOrElse(TextJson[List[Meta]](List.empty)).toJson,
"lastActiveUser" -> record.lastActiveUserId.toJson,
- "lastUpdate" -> record.lastUpdate.toJson
+ "lastUpdate" -> record.lastUpdate.toJson,
+ "totalPages" -> record.totalPages.toJson
)
override def read(json: JsValue): MedicalRecord = json match {
@@ -205,7 +206,8 @@ object record {
caseId = None,
physician = None,
meta = None,
- lastUpdate = LocalDateTime.now()
+ lastUpdate = LocalDateTime.now(),
+ totalPages = 0
)
case _ => deserializationError(s"Expected Json Object as MedicalRecord, but got $json")