/scala-js-skeleton.g8

Giter8 template for ScalaJS using Electron/Express

Primary LanguageJavaScript

ScalaJS Skeleton App

This is a Giter8 skeleton for ScalaJS. It can be launched with Electron or served with Express out-of-the-box. And launch configurations are pre-created for the Visual Studio Code editor. But, use of it is not required.

Getting Started

Download an install the following applications:

Next, run SBT on the command line to initialize a new sekeleton.

$ sbt new massung/scala-js-skeleton.g8 [-b webpack]

NOTE: If you'd like a skeleton that makes use of the ScalaJSBundler plugin and Webpack, then use the -b webpack branch of the repository.

Once the skeleton has been created, cd into it and install all the NodeJS dependencies with Yarn (or npm).

$ yarn install

Next, launch SBT and build the source for the skeleton.

sbt> fastOptJS

Note: if you are using the webpack branch, run fastOptJS::webpack instead.

At this point, you application's compiled .js file has been built and resides in the web/js folder along with a .js.map file and any other bundled, javascript dependencies.

To run your app, there are a few options:

If you are using VSCode, there are already launch configurations created for each: Run/Debug (Electron) and Serve (Express).

Otherwise, you can manually run/debug via the command line:

$ ./node_modules/.bin/electron main.js [debug]

If you pass the debug argument on the command line, then the webkit debugger will be opened as well. From there, you should have access to your Scala code, as a map file was generated for it.

Or start the Express server:

$ node server.js [port=8080]

That's it!

Structure

Here is a high-level breakdown of the skeleton source files:

  • project/ contains SBT plugins and settings
  • src/ contains all the ScalaJS app code
  • web/ contains all the static resources, and your app bundle
  • main.js is the Electron application code
  • server.js is the Express web server code

Everything in web/ will be exposed to your application at runtime. And the ScalaJS app will be compiled to JavaScript to web/js/ folder.