A site to publicize some of the most polluting buildings based on the Chicago Energy Benchmarking data published in the City of Chicago Data Portal.
It's powered by VueJS 2 and GridSome
Our data is only sourced from the city's benchmarking data:
GraphQL requires data key names to have no spaces or special characters, so there's a raw data file (only filtered by GHG emissions > 1,000 tons and year = 2020) and a cleaned file that just hast he headers renamed for GraphQL.
python and pandas for data processing
Leaflet and Leaflet Google mutant for maps (e.g. the map page)
Docker is the recommended approach to quickly getting started with local development. Docker helps create a version of the Electrify Chicago website on your computer so you can test out your code before submitting a pull request.
- The recommended installation method for your operating system can be found here.
- Get started with Docker
This command starts server locally. To start it, cd
into the project directory in your terminal then run the following command:
docker-compose up
Tip: Added a new dependency? Once you've updated the package.json
run
docker-compose up --build
to rebuild the image, which will re-run the setup steps in the
Dockerfile
.
Running the above command will result in the following output in your terminal
When you see the above output, it means the site is now running and now you can browse to http://localhost:8080
- To stop and completely remove the server (i.e. the running Docker container), run
docker-compose down
- To stop the server, but not destroy it (often sufficient for day-to-day work), run
docker-compose stop
- Bring the same server back up later with
docker-compose up
To run linting with auto-fixing (ESLint + Prettier), run the following command:
docker-compose run --rm electrify-chicago yarn lint-fix
-
If you update the raw data CSVs or the data scripts that post-process them (like if you are adding a new statistical analysis), you need to re-run the data processing.
-
To then process a new CSV file (at
src/data/source/ChicagoEnergyBenchmarking.csv
), you need to run the following command:
docker-compose run --rm electrify-chicago bash run_all.sh
- Make sure test data is created/replaced before running tests by running the following script (it will overwrite the existing test data file if it exists):
docker-compose run --rm electrify-chicago bash create_test_data.sh
- To run all tests in the project directory, enter the following command:
docker-compose run --rm electrify-chicago python -m pytest
- Run the following command for individual unit test suite (where YOUR_FILE_NAME is something like
test_clean_all_years
):
docker-compose run --rm electrify-chicago python -m pytest tests/data/scripts/unit/YOUR_FILE_NAME.py
If there's a new large building owner to add, simply:
- Add the building owner in the
BuildingOwners
constant inbuildings-custom-info.constant.vue
- this defines metadata about the owner like their name and logo URLs
Example:
iit: {
key: 'iit',
name: 'Illinois Institute of Technology',
nameShort: 'Illinois Tech',
logoSmall: '/building-owners/iit/logo-small.png',
logoLarge: '/building-owners/iit/logo-large.svg',
}
- Tag buildings they own in the
BuildingsCustomInfo
constant (in the samebuildings-custom-info.constant.vue
file) - this associates a given building (by its numeric unique ID, found under its address on its details page), with a given owner.
Example:
// Keating Hall
'256434': {owner: BuildingOwners.iit.key},
- Setup their route by adding the new owner's ID (key) to
BuildingOwnerIds
(ingridsome.server.js
) - this tells Gridsome to create a route for this given slug
Example:
const BuildingOwnerIds = [
'iit',
// ...
];
Note: You'll have to restart your yarn develop
after step 3 to see changes, since
gridsome.server.js
just runs once.
- *Find A Suitable Image -- Building images can be sourced from Google Maps or a source that allows redistribution, like Wikimedia.
2 Process the Image
We should reasonably crop images if needed and then scale them to be EITHER:
- 1000px wide if it's a landscape image
- 600px wide if it's a portrait image
Make sure to export it as a .jpg
image at a quality level of 70, which should ensure a reasonable
file size under 200 kB.
**Store the image in /static/building-imgs/
.
-
Tell The Site There's a Building Image - Follow the pattern of other buildings in the
building-images.constant.vue
, providing an attribution URL, the image file name, and specify whether it's a tall (portrait) image and whether it's from Google Maps. -
Confirm the image is visible and looks good - and that's all there is to it!
This site deploys automatically via Netlify by running gridsome build
.