generated from MarkCLewis/play-scalajs-slinky
-
Notifications
You must be signed in to change notification settings - Fork 1
/
build.sbt
56 lines (49 loc) · 1.88 KB
/
build.sbt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
import sbtcrossproject.{crossProject, CrossType}
enablePlugins(JavaAppPackaging)
Global / onChangedBuildSource := ReloadOnSourceChanges
lazy val server = (project in file("server")).settings(commonSettings).settings(
name := "play-server",
scalaJSProjects := Seq(client),
pipelineStages in Assets := Seq(scalaJSPipeline),
pipelineStages := Seq(digest, gzip),
// triggers scalaJSPipeline when using compile or continuous compilation
compile in Compile := ((compile in Compile) dependsOn scalaJSPipeline).value,
libraryDependencies ++= Seq(
"com.vmunier" %% "scalajs-scripts" % "1.1.4",
guice,
"org.scalatestplus.play" %% "scalatestplus-play" % "5.1.0" % Test,
"com.typesafe.play" %% "play-slick" % "5.0.0",
"com.typesafe.slick" %% "slick-codegen" % "3.3.3",
"org.postgresql" % "postgresql" % "42.2.18",
"com.typesafe.slick" %% "slick-hikaricp" % "3.3.3",
specs2 % Test
)
).enablePlugins(PlayScala).
dependsOn(sharedJvm)
lazy val client = (project in file("client")).settings(commonSettings).settings(
name := "play-client",
scalaJSUseMainModuleInitializer := true,
libraryDependencies ++= Seq(
"org.scala-js" %%% "scalajs-dom" % "1.1.0",
"me.shadaj" %%% "slinky-core" % "0.6.6",
"me.shadaj" %%% "slinky-web" % "0.6.6"
),
scalacOptions += "-Ymacro-annotations"
).enablePlugins(ScalaJSPlugin, ScalaJSWeb).
dependsOn(sharedJs)
lazy val shared = crossProject(JSPlatform, JVMPlatform)
.crossType(CrossType.Pure)
.in(file("shared"))
.settings(commonSettings)
.settings(
name := "play-shared"
)
lazy val sharedJvm = shared.jvm
lazy val sharedJs = shared.js
lazy val commonSettings = Seq(
scalaVersion := "2.13.4",
organization := "edu.trinity",
libraryDependencies += "com.typesafe.play" %% "play-json" % "2.9.1"
)
// loads the server project at sbt startup
onLoad in Global := (onLoad in Global).value andThen {s: State => "project server" :: s}