This is a Giter8 template showing how you can integrate an Akka HTTP project with a Scala.js project.
$ sbt new vmunier/akka-http-scalajs.g8
$ cd akka-http-scalajs
$ sbt
sbt:root> project server
sbt:server> ~reStart
$ open http://localhost:8080The application contains three directories:
serverAkka HTTP application (server side)clientScala.js application (client side)sharedScala code that you want to share between the server and the client
The application uses the sbt-web-scalajs sbt plugin.
compile,run,reStarttrigger the Scala.jsfastLinkJStask~compile,~run,~reStartcontinuous compilation is also available- Set
scalaJSStagetoFullOptStagewhen packaging your application forfullLinkJSto be executed instead offastLinkJS:sbt 'set Global / scalaJSStage := FullOptStage' Universal/packageBin - Source maps
- Open your browser dev tool to set breakpoints or to see the guilty line of code when an exception is thrown.
- Source Maps are enabled in both
fastLinkJSandfullLinkJSby default. If you wish to disable Source Maps infullLinkJS, then addCompile / fullLinkJS / scalaJSLinkerConfig ~= (_.withSourceMap(false))in the Scala.js projects.
The root project aggregates all the other projects. Use this root project to clean all the projects at once.
$ sbt
sbt:root> cleanAdd the following line to build.sbt if you wish to load the server project at sbt startup:
Global / onLoad := (Global / onLoad).value.andThen(state => "project server" :: state)clean will only delete the server's generated files (in the server/target directory). Call root/clean to delete the generated files for all the projects.
In IntelliJ, open Project wizard, select Import Project, choose the root folder and click OK.
Select Import project from external model option, choose SBT project and click Next. Select additional import options and click Finish.
Make sure you use the IntelliJ Scala Plugin v2017.2.7 or higher. There are known issues with prior versions of the plugin.
- Add
addSbtPlugin("com.typesafe.sbteclipse" % "sbteclipse-plugin" % "5.2.4")toproject/plugins.sbt - Add the following lines to the
server's settings inbuild.sbt:
// Compile the project before generating Eclipse files, so that generated .scala or .class files for Twirl templates are present
EclipseKeys.preTasks := Seq(Compile / compile)
- Run
$ sbt "eclipse with-source=true" - Inside Eclipse,
File/Import/General/Existing project..., choose the root folder. Uncheck the third checkbox to only import client, server and shared/.jvm, clickFinish.
The assets (js files, sourcemaps, etc.) are added to the classpath during development thanks to the following lines:
Assets / WebKeys.packagePrefix := "public/",
Runtime / managedClasspath += (Assets / packageBin).value
Note that Assets / packageBin also executes any tasks appended to pipelineStages, e.g. gzip.
You may want to avoid executing tasks under pipelineStages during development, because it could take long to execute.
In that case, in order to still have access to the assets under Assets / WebKeys.packagePrefix during development, you can use the following code instead:
lazy val server = project.settings(
...
Assets / WebKeys.packagePrefix := "public/",
Assets / WebKeys.exportedMappings ++= (for ((file, path) <- (Assets / mappings).value)
yield file -> ((Assets / WebKeys.packagePrefix).value + path)),
...
)