lila/app/controllers/QaQuestion.scala

111 lines
3.4 KiB
Scala

package controllers
import play.api.data.Form
import play.api.mvc._
import lila.api.Context
import lila.app._
import lila.qa.{ QuestionId, Question, AnswerId, Answer, QuestionWithUsers, QaAuth }
import views._
object QaQuestion extends QaController {
def index(page: Option[Int] = None) = Open { implicit ctx =>
api.question.paginatorWithUsers(page getOrElse 1, 20) zip
(api.question popular 10) map {
case (questions, popular) => Ok(html.qa.index(questions, popular))
}
}
def search = Open { implicit ctx =>
val query = ~get("q")
(query match {
case "" => (api.question recent 20 flatMap api.question.zipWithUsers)
case _ => Env.qa search query flatMap api.question.zipWithUsers
}) zip (api.question popular 10) map {
case (questions, popular) => Ok(html.qa.search(query, questions, popular))
}
}
def byTag(tag: String) = Open { implicit ctx =>
(api.question.byTag(tag, 20) flatMap api.question.zipWithUsers) zip
(api.question popular 10) map {
case (questions, popular) => Ok(html.qa.byTag(tag, questions, popular))
}
}
def show(id: QuestionId, slug: String) = Open { implicit ctx =>
WithQuestion(id, slug) { q =>
(api.question incViews q) >> renderQuestion(q)
}
}
private def renderAsk(form: Form[_], status: Results.Status)(implicit ctx: Context) =
api.question popular 10 zip api.tag.all map {
case (popular, tags) => status(html.qa.ask(form, tags, popular))
}
def ask = Auth { implicit ctx =>
_ =>
renderAsk(forms.question, Results.Ok)
}
def doAsk = AuthBody { implicit ctx =>
me =>
implicit val req = ctx.body
forms.question.bindFromRequest.fold(
err => renderAsk(err, Results.BadRequest),
data => api.question.create(data, me) map { q =>
Redirect(routes.QaQuestion.show(q.id, q.slug))
}
)
}
def edit(id: QuestionId, slug: String) = Auth { implicit ctx =>
me =>
WithOwnQuestion(id, slug) { q =>
renderEdit(forms editQuestion q, q, Results.Ok)
}
}
def doEdit(id: QuestionId) = AuthBody { implicit ctx =>
me =>
WithOwnQuestion(id) { q =>
implicit val req = ctx.body
forms.question.bindFromRequest.fold(
err => renderEdit(err, q, Results.BadRequest),
data => api.question.edit(data, q.id) map {
case None => NotFound
case Some(q2) => Redirect(routes.QaQuestion.show(q2.id, q2.slug))
}
)
}
}
private def renderEdit(form: Form[_], q: Question, status: Results.Status)(implicit ctx: Context) =
api.question popular 10 zip api.tag.all map {
case (popular, tags) => status(html.qa.edit(form, q, tags, popular))
}
def vote(id: QuestionId) = AuthBody { implicit ctx =>
me =>
implicit val req = ctx.body
forms.vote.bindFromRequest.fold(
err => fuccess(BadRequest),
v => api.question.vote(id, me, v == 1) map {
case Some(vote) => Ok(html.qa.vote(routes.QaQuestion.vote(id).url, vote))
case None => NotFound
}
)
}
def remove(questionId: QuestionId) = Secure(_.ModerateQa) { implicit ctx =>
me =>
WithQuestion(questionId) { q =>
(api.question remove q.id) >>
Env.mod.logApi.deleteQaQuestion(me.id, q.userId, q.title) inject
Redirect(routes.QaQuestion.index())
}
}
}