org.scalatra.forms.views.scala Maven / Gradle / Ivy
package org.scalatra.forms
import javax.servlet.http.HttpServletRequest
import org.scalatra.MultiParams
/**
* Provides view helpers to render form elements.
*/
object views {
/**
* Render a text field.
*/
def text(name: String, attributes: (String, String)*)(implicit request: HttpServletRequest): String = {
s""""""
}
/**
* Render a password field.
*/
def password(name: String, attributes: (String, String)*)(implicit request: HttpServletRequest): String = {
s""""""
}
/**
* Render a textarea.
*/
def textarea(name: String, attributes: (String, String)*)(implicit request: HttpServletRequest): String = {
s""""""
}
/**
* Render a checkbox.
*/
def checkbox(name: String, value: String, attributes: (String, String)*)(implicit request: HttpServletRequest): String = {
val checked = if (params(name).contains(value)) "checked" else ""
s""""""
}
/**
* Render a radio button.
*/
def radio(name: String, value: String, attributes: (String, String)*)(implicit request: HttpServletRequest): String = {
val checked = if (param(name) == value) "checked" else ""
s""""""
}
/**
* Render a select box.
*/
def select(name: String, values: Seq[(String, String)], multiple: Boolean, attributes: (String, String)*)(implicit request: HttpServletRequest): String = {
val sb = new StringBuilder()
sb.append(s"""")
sb.toString
}
/**
* Retrieve an error message of the specified field.
*/
def error(name: String)(implicit request: HttpServletRequest): Option[String] = {
Option(request.getAttribute(RequestAttributeErrorsKey)).flatMap { errors =>
errors.asInstanceOf[Seq[(String, String)]].find(_._1 == name).map(_._2)
}
}
/**
* Retrieve all error messages of the specified field.
*/
def errors(name: String)(implicit request: HttpServletRequest): Seq[String] = {
Option(request.getAttribute(RequestAttributeErrorsKey)).map { errors =>
errors.asInstanceOf[Seq[(String, String)]].collect { case error if error._1 == name => error._2 }
}.getOrElse(Nil)
}
private def escape(value: String): String = {
value.replace("&", "&").replace("<", "<").replace(">", ">").replace("\"", """)
}
private def params(name: String)(implicit request: HttpServletRequest): Seq[String] = {
Option(request.getAttribute(RequestAttributeParamsKey)).flatMap { params =>
params.asInstanceOf[MultiParams].get(name)
}.getOrElse(Nil)
}
private def param(name: String)(implicit request: HttpServletRequest): String = {
params(name).headOption.getOrElse("")
}
private def attrs(attrs: (String, String)*): String = {
attrs.map { case (name, value) => s"""${escape(name)}="${escape(value)}"""" }.mkString(" ")
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy