diff options
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuidomain/formats/json/label')
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 + ) +} |