aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuidomain/formats/json/keyword/ApiKeyword.scala
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/keyword/ApiKeyword.scala
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/keyword/ApiKeyword.scala')
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/formats/json/keyword/ApiKeyword.scala23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/formats/json/keyword/ApiKeyword.scala b/src/main/scala/xyz/driver/pdsuidomain/formats/json/keyword/ApiKeyword.scala
new file mode 100644
index 0000000..afd012d
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/formats/json/keyword/ApiKeyword.scala
@@ -0,0 +1,23 @@
+package xyz.driver.pdsuidomain.formats.json.keyword
+
+import xyz.driver.pdsuidomain.entities.KeywordWithLabels
+import play.api.libs.functional.syntax._
+import play.api.libs.json.{Format, JsPath}
+import xyz.driver.pdsuidomain.formats.json.label.ApiLabel
+
+final case class ApiKeyword(id: Long, keyword: String, labels: List[ApiLabel])
+
+object ApiKeyword {
+
+ implicit val format: Format[ApiKeyword] = (
+ (JsPath \ "id").format[Long] and
+ (JsPath \ "keyword").format[String] and
+ (JsPath \ "labels").format[List[ApiLabel]]
+ ) (ApiKeyword.apply, unlift(ApiKeyword.unapply))
+
+ def fromDomain(keywordWithLabels: KeywordWithLabels) = ApiKeyword(
+ id = keywordWithLabels.keyword.id.id,
+ keyword = keywordWithLabels.keyword.keyword,
+ labels = keywordWithLabels.labels.map(x => ApiLabel(x.id.id, x.name, x.categoryId.id))
+ )
+}