aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuidomain/formats/json/label
diff options
context:
space:
mode:
authorvlad <vlad@driver.xyz>2017-06-27 17:13:02 -0700
committervlad <vlad@driver.xyz>2017-06-27 17:13:02 -0700
commit5832f63b84d7388441d1200f2442dc1e9de0225c (patch)
tree32f63acdc920c14effc3d0d2822c05c125ad49e4 /src/main/scala/xyz/driver/pdsuidomain/formats/json/label
parent9dd50590d4c8f8b9442d7c21ddd1def9dd453d5e (diff)
downloadrest-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/label')
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/formats/json/label/ApiCriterionLabel.scala49
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/formats/json/label/ApiExtractedDataLabel.scala36
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/formats/json/label/ApiLabel.scala22
3 files changed, 107 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/label/ApiCriterionLabel.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/label/ApiCriterionLabel.scala
new file mode 100644
index 0000000..2788bf2
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/label/ApiCriterionLabel.scala
@@ -0,0 +1,49 @@
+package xyz.driver.pdsuidomain.formats.json.label
+
+import xyz.driver.pdsuicommon.domain.{FuzzyValue, LongId}
+import xyz.driver.pdsuidomain.entities.{Category, Criterion, CriterionLabel, Label}
+import play.api.data.validation.ValidationError
+import play.api.libs.functional.syntax._
+import play.api.libs.json._
+
+/**
+ * @param value Yes|No
+ */
+final case class ApiCriterionLabel(labelId: Option[Long],
+ categoryId: Option[Long],
+ value: Option[String],
+ isDefining: Boolean) {
+
+ def toDomain(criterionId: LongId[Criterion]) = CriterionLabel(
+ id = LongId(0L),
+ labelId = labelId.map(LongId[Label]),
+ criterionId = criterionId,
+ categoryId = categoryId.map(LongId[Category]),
+ value = value.map {
+ case "Yes" => true
+ case "No" => false
+ },
+ isDefining = isDefining
+ )
+}
+
+object ApiCriterionLabel {
+
+ def fromDomain(x: CriterionLabel) = ApiCriterionLabel(
+ labelId = x.labelId.map(_.id),
+ categoryId = x.categoryId.map(_.id),
+ value = x.value.map { x =>
+ FuzzyValue.valueToString(FuzzyValue.fromBoolean(x))
+ },
+ isDefining = x.isDefining
+ )
+
+ implicit val format: Format[ApiCriterionLabel] = (
+ (JsPath \ "labelId").formatNullable[Long] and
+ (JsPath \ "categoryId").formatNullable[Long] and
+ (JsPath \ "value").formatNullable[String](Format(Reads.of[String].filter(ValidationError("unknown value"))({ x =>
+ x == "Yes" || x == "No"
+ }), Writes.of[String])) and
+ (JsPath \ "isDefining").format[Boolean]
+ ) (ApiCriterionLabel.apply, unlift(ApiCriterionLabel.unapply))
+}
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/label/ApiExtractedDataLabel.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/label/ApiExtractedDataLabel.scala
new file mode 100644
index 0000000..9159d27
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/label/ApiExtractedDataLabel.scala
@@ -0,0 +1,36 @@
+package xyz.driver.pdsuidomain.formats.json.label
+
+import xyz.driver.pdsuicommon.domain.{FuzzyValue, LongId}
+import xyz.driver.pdsuidomain.entities.{Category, ExtractedData, ExtractedDataLabel, Label}
+import play.api.data.validation.ValidationError
+import play.api.libs.functional.syntax._
+import play.api.libs.json._
+
+final case class ApiExtractedDataLabel(id: Option[Long], categoryId: Option[Long], value: Option[String]) {
+
+ def toDomain(dataId: LongId[ExtractedData] = LongId(0)) = ExtractedDataLabel(
+ id = LongId(0),
+ dataId = dataId,
+ labelId = id.map(LongId[Label]),
+ categoryId = categoryId.map(LongId[Category]),
+ value = value.map(FuzzyValue.fromString)
+ )
+}
+
+object ApiExtractedDataLabel {
+
+ implicit val format: Format[ApiExtractedDataLabel] = (
+ (JsPath \ "id").formatNullable[Long] and
+ (JsPath \ "categoryId").formatNullable[Long] and
+ (JsPath \ "value").formatNullable[String](Format(Reads.of[String].filter(ValidationError("unknown value"))({
+ case x if FuzzyValue.fromString.isDefinedAt(x) => true
+ case _ => false
+ }), Writes.of[String]))
+ ) (ApiExtractedDataLabel.apply, unlift(ApiExtractedDataLabel.unapply))
+
+ def fromDomain(dataLabel: ExtractedDataLabel) = ApiExtractedDataLabel(
+ id = dataLabel.labelId.map(_.id),
+ categoryId = dataLabel.categoryId.map(_.id),
+ value = dataLabel.value.map(FuzzyValue.valueToString)
+ )
+}
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/label/ApiLabel.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/label/ApiLabel.scala
new file mode 100644
index 0000000..8c30f3a
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/label/ApiLabel.scala
@@ -0,0 +1,22 @@
+package xyz.driver.pdsuidomain.formats.json.label
+
+import play.api.libs.functional.syntax._
+import play.api.libs.json.{Format, JsPath}
+import xyz.driver.pdsuidomain.entities.Label
+
+final case class ApiLabel(id: Long, name: String, categoryId: Long)
+
+object ApiLabel {
+
+ implicit val format: Format[ApiLabel] = (
+ (JsPath \ "id").format[Long] and
+ (JsPath \ "name").format[String] and
+ (JsPath \ "categoryId").format[Long]
+ ) (ApiLabel.apply, unlift(ApiLabel.unapply))
+
+ def fromDomain(x: Label) = ApiLabel(
+ id = x.id.id,
+ name = x.name,
+ categoryId = x.categoryId.id
+ )
+}