Source code for NEScala web site
- You'll need to install SBT
- You'll want a decent editor or IDE.
- You'll need to understand at least a little bit about Unfiltered.
- You'll have to wrap your brain around the occasionally confusing source code layout. If you're having trouble grokking it, contact one of the maintainers.
Before you deploy the site, you must ensure that you can run
it locally. Doing so requires a meetup.properties
file (which is never
committed, for security reasons). Contact one of the maintainers to get a
working copy, and install that copy in src/main/resources
. (The
.gitignore
file ensures that it'll never be committed.)
When running live, this file isn't necessary, because Heroku configuration properties are used, instead.
$ sbt
...
> ;clean;compile
...
You can run the server in two ways.
With the run
command in sbt
:
> run
will run on port 8080. You can also specify a port number:
> run 9090
To stop the run, just hit ENTER.
You can also use sbt-revolver
. To start:
> re-start
or
> re-start 9090
To stop:
> re-stop
-
Web content: If it's web site content you want to update, the templates for the current year are in
src/main/scala/boston2018/Templates.scala
. -
CSS: If you need to hack on the CSS rules, the 2016 code uses LESS, while the 2018 code used Sass (but now just uses the compiled css), and previous years use straight CSS. The Philly 2016 LESS rules are in
src/main/assets/css/philly2016.less
. Sass files end with.scss
, and those with filenames starting with an underscore are not compiled into matching css files. If you don't understand LESS or Sass, don't hack the CSS until you do. -
Static resources: Anything in
src/main/resources/www
is served as a static resource. That is, URL path/foo.png
corresponds to filesrc/main/resources/www/foo.png
, and/www/js/nyc.js
corresponds tosrc/main/resources/www/js/nyc.js
. (That's why thefavicon.ico
file is insrc/main/resources/www
.)
For simplicitly, the 2016 schedule is read from a CSV file, which is,
itself, merely a CSV download of a Google Spreadsheet. The code assumes
that the schedule is loadable as resource /www/2016/Schedule.csv
(so the current schedule is always located at
src/main/resources/2016/Schedule.csv
in the code).
The code also assumes that the first line is a header line, and it looks for these headers, interpreted the associated column values as described:
- "Activity": The short name of the activity. This could be "Lunch", "Break", or a talk title.
- "Description": The full description of the entry. This field can contain Markdown. It can also be empty.
- "Speaker": The speaker, if the row is for a talk, or empty otherwise.
- "Start": The start time of the entry, in "HH:mm a" format (e.g., "8:30 AM", "4:00 PM"). Required.
- "Duration": The duration, in hours and minutes. e.g., "0:40" for 40 minutes, "1:15" for an hour and fifteen minutes. Required.
- "Meetup ID": The meetup ID of the speaker, if the row is a talk. Empty otherwise.
Any other headers (and corresponding columns) are ignored.
Thus, to update the schedule:
- Edit the Google Spreadsheet.
- Download as CSV.
- Copy to
src/main/resources/www/2016/Schedule.csv
- Compile and run locally, and verify that the schedule looks right.
- Deploy.
We're running on Heroku. You won't be able to push to Heroku unless:
- you have a Heroku account, and
- you are listed as a collaborator on the Heroku application.
Contact one of the maintainers for access.
You'll need to install the Heroku CLI, and you must use it to login, as described in the documentation.
Next, you'll need to add a Git remote to your cloned copy of this repo:
$ git remote add heroku [email protected]:nescala.git
You also need to ensure that the app has the heroku/scala
buildpacks installed,
but that should carry over from previous years.
Assuming you've properly prepared your environment, you can deploy with a single Git command:
$ git push heroku master
If you prefer, you can also deploy from the Heroku dashboard Deploy tab. The application has been linked to the main Git repo. If your changes are pushed to the main repo, you can deploy them from the Manual Deploy section of the Deploy tab. (Honestly, though, the command line is faster.)
If you want to run the site on a non-Heroku server (e.g., for testing), you can build a fat jar and run it:
$ sbt fatjar
That command builds target/scala_2.10/root-assembly-0.1-SNAPSHOT.jar
,
which you can run with java -jar
.