Skip to content

Latest commit

 

History

History
106 lines (73 loc) · 3.89 KB

README.md

File metadata and controls

106 lines (73 loc) · 3.89 KB

ENERGY OUTREACH COLORADO

KNOW THE TRUE LEVEL OF ENERGY NEED IN CO

The Energy Assistance Dashboard is an interactive single-page web application for visualizing and tracking data related to low-income energy assistance through Energy Outreach Colorado.

The purpose of the dashboard is to provide an understanding of how much energy need is in a specific place.

About

How It Works

There are really two parts to this web application:

  1. The first part is the user-facing side, which is a web page that displays a dashboard of energy visualizations. The design of this dashboard will be based on the version 1 visualization mockup found below in the Google Sheet.

  2. The other part is the admin-facing side, which is an Airtable document that stores the data which feeds the user-facing visualizations. Currently, the data can also be found below in the Google Sheet.

The idea is that administrators will be able to easily update the Airtable document and users will see changes reflected in the web dashboard.

Project Goals

The must haves of the project are that it:

  1. Is printable.
  2. Easily administered and updated by non-technical users.

Stretch goal ideas:

  • Automating data collection
  • Adding more types of data

Resources

Development

On the technology side, the project is split into two parts, a backend HTTP API and a web frontend. The backend API is being built with Python 3.6+ and FastAPI. The frontend stack is still being decided.

Backend Setup

  1. Install python3

  2. Navigate to the project folder and setup a virtual environment named venv by running the command: python3 -m venv venv

  3. Activate the virtual environment: Find the proper activate script based on your OS and terminal. https://docs.python.org/3/library/venv.html

    • For macOS terminal use: source venv/bin/activate

    • Note: For macOS the venv can be deactivated by typing deactivate in the terminal

  4. Navigate to the backend folder

  5. Install dependencies: pip install -r requirements.txt

  6. If adding new dependencies, update the requirements file by running: pip-chill > requirements.txt

    • We are using pip-chill which will only list top-level requirements.
  7. Add the .env file to the backend folder

  8. Start the server uvicorn backend.main:app --reload

  9. Navigate to http://127.0.0.1:8000/ to view the server locally

Frontend Setup

  1. Navigate to the frontend folder

  2. Install dependencies yarn install

    1. If yarn is not installed, brew install yarn
  3. Run the dev server yarn dev

  4. Navigate to http://127.0.0.1:3000/ to view the frontend client locally

Testing

  1. From the root or backend (or eventually front end folder), run pytest. This will look for files that start with test_.

  2. To run tests with coverage, run covereage run -m pytest followed by coverage report.

    1. coverage report -m will show more detail, including line numbers that are not being tested.
    2. coverage html -d coverage_html will create html reports, with hyperlinked access to see the code itself. Open up coverage_html/index.html in your browser.
    3. Coverage has a lot of options. You can read the docs here: https://coverage.readthedocs.io/en/coverage-5.1/index.html