not found: type MessagesRequestHeader のエラー解決
Scala/PlayFrameworkを学習中です。
現在、slickを使いデータベースからデータをテンプレートに表示する作業を行っています。
タイプミスは確認しましたがないと思います。何が原因でのエラーか理解できていません。
よろしくお願い致します。
発生している問題・エラーメッセージ
not found: type MessagesRequestHeader
build.sbt
name := """play/slickApp""" organization := "con.example" version := "1.0-SNAPSHOT" lazy val root = (project in file(".")).enablePlugins(PlayJava) scalaVersion := "2.12.6" libraryDependencies += guice libraryDependencies += "org.scalatextplus.play" %% "scalatextplus-play" % "3.1.2" % "Test" libraryDependencies += "com.h2database" % "h2" % "1.4.197" libraryDependencies += "com.typesafe.play" %% "play-slick" % "3.0.3" libraryDependencies += "com.typesafe.play" %% "play-slick-evolutions" % "3.0.3"
HomeController.scala (コントローラ)
package controllers import javax.inject._ import models._ import play.api.data.Form import play.api.data.Forms._ import play.api.data.validation.Constraints._ import play.api.i18n._ import play.api.libs.json.Json import play.api.mvc._ import scala.concurrent.{ExecutionContext, Future} @Singleton class HomeController @Inject()(repository: PersonRepository, cc: MessagesControllerComponents) (implicit ec:ExecutionContext) extends MessagesAbstractController(cc) { def index() = Action.async { implicit request => repository.list().map { implicit people => Ok(views.html.index( "People Data", people )) } }
Person.scala (モデル)
package models import play.api.data.Form import play.api.data.Forms._ object Person { val personform: Form[PersonForm] = Form { mapping( "name" -> text, "mail" -> text, "tel" -> text )(PersonForm.apply)(PersonForm.unapply) } } case class Person(id: Int, name: String, mail: String, tel: String) case class PersonForm(name: String, mail: String, tel: String)
index.scala.html (テンプレート)
@(message: String, data: Seq[models.Person])(implicit request: MessagesRequestHeader) @main("Index Page", "Hello!", "copyright 2021.") { <p>@Html(message)</p> <ul> @for(item <- data) { <li>@item.id: @item.name [@item.mail, @item.tel]</li> } </ul> }
PresonRepository.scala (リポジトリ)
package models import javax.inject.{ Inject, Singleton } import play.api.db.slick.DatabaseConfigProvider import slick.jdbc.JdbcProfile import scala.concurrent.{ Future, ExecutionContext } @Singleton class PersonRepository @Inject() (dbConfigProvider: DatabaseConfigProvider) (implicit ec: ExecutionContext) { private val dbConfig = dbConfigProvider.get[JdbcProfile] import dbConfig._ import profile.api._ private class PeopleTable(tag: Tag) extends Table[Person](tag, "people") { def id = column[Int]("id", O.PrimaryKey, O.AutoInc) def name = column[String]("name") def mail = column[String]("mail") def tel = column[String]("tel") def * = (id, name, mail, tel) <> ((Person.apply _).tupled, Person.unapply) } private val people = TableQuery[PeopleTable] def list(): Future[Seq[Person]] = db.run { people.result } }
バージョン
Scala 2.12.6
Play 1.0-SNAPSHOT
H2 1.4.197
slick 3.0.3
slick-evolutions 3.0.3
あなたの回答
tips
プレビュー