example/src/sqwl/cms/Articles.scala
author Tomas Zeman <tzeman@volny.cz>
Thu, 13 Dec 2018 14:21:10 +0100
changeset 18 8cfd67425811
child 21 1fa630ed9b8a
permissions -rw-r--r--
Scalatex article as primary format
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
18
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     1
package sqwl.cms
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     2
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     3
import java.nio.file.{Path, Paths}
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     4
import scala.collection.mutable
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     5
import scalatags.Text.all._
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     6
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     7
object Articles {
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     8
  case class Id(val v: String)
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     9
  case class Article(
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    10
    val id: Id,
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    11
    val title: String,
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    12
    val category: Option[iCategory],
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    13
    val tags: Seq[iTag] = Seq(),
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    14
    val htmlContent: String
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    15
  ) extends iArticle {
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    16
    override def assets: Path = Paths.get(s"example/content/${id.v}")
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    17
    override def pathSegment: String = id.v
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    18
  }
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    19
  private val all = mutable.ArrayBuffer[iArticle]()
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    20
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    21
  def values: Seq[iArticle] = all.toSeq
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    22
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    23
  def article(title: String, cat: iCategory, tags: Seq[iTag] = Seq())(
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    24
    body: Frag*)(implicit articleId: Id): SeqFrag[Frag] = {
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    25
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    26
    all += Article(articleId, title, Option(cat), tags, body.render)
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    27
    body
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    28
  }
8cfd67425811 Scalatex article as primary format
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    29
}