Home

Awesome

Play Framework with Scala.js

License Gitter

This is a Giter8 template showing how you can integrate a Play project with a Scala.js project.

Run the application

$ sbt new vmunier/play-scalajs.g8
$ cd play-scalajs
$ sbt
sbt:root> project server
[server] run
$ open http://localhost:9000

The application contains three directories:

Features

The application uses the sbt-web-scalajs sbt plugin.

Cleaning

The root project aggregates all the other projects. Use this root project to clean all the projects at once.

$ sbt
sbt:root> clean

Load the server project at sbt startup

Add 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.

IDE integration

IntelliJ

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.

Eclipse

  1. Add addSbtPlugin("com.typesafe.sbteclipse" % "sbteclipse-plugin" % "5.2.4") to project/plugins.sbt
  2. Add the following lines to the server's settings in build.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)
  1. Run $ sbt "eclipse with-source=true"
  2. Inside Eclipse, File/Import/General/Existing project..., choose the root folder. Uncheck the third checkbox to only import client, server and shared/.jvm, click Finish. Alt text