Website for the OpenElections project. It displays project status and offers an interface to download results data.
This site is built using the Jekyll static site builder.
To install Jekyll and some other dependencies, first make sure you have gem and bundler installed.
gem install bundler
Then use bundler to install the dependencies
cd ~/workspace/openelections.github.io
bundle install
To build the site, run:
bundle exec jekyll build
bundle exec jekyll serve --watch --baseurl '' -P 8000
Then you can access this project in your browser at http://localhost:8000.
Information about the project status and the availability of downloadable results for individual elections is stored in JSON files in the data
directory. These files will sometimes need to be updated from data in the dashboard and core apps.
These tasks can be run either within the environment of these apps, or remotely, using Fabric tasks in the openelex-config
repo.
To update the state_status.json
file, which drives the map and table on the home page and the state status in the sidebar, do one of the following:
From the dashboard app's environment, run:
django-admin.py create_status_json > /path/to/data/state_status.json
or using Fabric, run:
fab -R prod create_status_json:outputfilename=/path/to/data/state_status.json
The election results availability files are stored as data/elections-{state_abbrev}.json
. This data drives the elections visualization and download table for each state.
To generate the election results availability for a state, the data for the elections needs to be loaded into the database. Then, do one of the following:
From the core app's environment, run:
openelex bake.results_status_json --state=WY > /path/to/data/elections-wy.json
or using Fabric, run:
fab -R prod bake_results_status_json:state=WY,outputfilename=/path/to/data/elections-wy.json
In either case, replace "WY" with the abbreviation of the state whose metadata you want to generate.
Presently, we use GitHub pages as an inexpensive, easy to deploy, hosting strategy for the website.
Due to the need to host both the API and this website on the openelections.net domain, we proxy requests on our web head to openelections.github.io, the default domain for a GitHub-pages hosted site for an organization.
Naming the repository openelections.github.io
is a convention that causes this site to be hosted at http://openelections.github.io. It also allows the site to be deployed by pushing to the master
branch on GitHub rather than pushing to the gh-pages
branch.
After making any changes to the markdown, template, JavaScript, metadata JSON, etc., testing things out with jekyll serve
, commit the changes locally.
Then push the changes to the master
branch of the remote repository on GitHub:
git push origin master
- Margie Roswell (@mroswell)
- Chloe Whiteaker