Skip to content

The Green Neighbor Challenge letter builder helps users learn about energy policies in their state, select policies they care about, connects them to their state representatives, and helps them send an email advocating for policy change.

Notifications You must be signed in to change notification settings

targeter21/letter-builder

 
 

Repository files navigation

Green Neighbor Letter Builder

Full stack web app built for the Green Neighbor Challenge. This app helps users learn about energy policies in their state, and contact their elected officials to advocate for green policies. Users can view educational info about major policies, see how their state ranks, and then begin the letter builder. The letter builder helps them pick the issues they care about, customize the letter text, identify their reps, and send the letter!

On the admin side, Green Neighbor staff can edit and update all of the data that fills the letter builder, including petition text, policy info, and state by state data.

Screenshots

Title Letter builder Pick Reps Admin form

Getting Started

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.

Prerequisites

Installation

  1. Create a database named 'greenNeighbor'.
  2. The queries in the database.sql file are set up to create all the necessary tables and populate the needed data to allow the application to run correctly. The project is built on Postgres, so you will need to make sure to have that installed. We recommend using Postico to run those queries as that was used to create the queries,
  3. There is also a file for each table that contains insert statements to get the core data entered for the app to run.
  4. Open up your editor of choice and run an npm install
  5. Run npm run server in your terminal
  6. Run npm run client in your terminal
  7. The npm run client command will open up a new browser tab for you!

Creating the .ENV

  • Create a .env file at the root of your project. This file will require several pieces of information that will each need to acquired separately. Further instructions on obtaining these keys are provided below:
    SERVER_SESSION_SECRET = ***********
    zip_key = ********************
    API_KEY = ********************
    

First you will need to establish a SERVER_SESSION_SECRET to keep your application secure. Here's a site that can help you generate a secret: https://passwordsgenerator.net/. NOTE This secret should be more than 8 characters. Having a secret key that is less than 8 characters will result in a warning from the app.

Google Geocoding API

This app uses the Google Geocoding API to convert zip codes to state information. To use this API, you must create a developer account, provide billing information, and enable the Geocoding API. You can reference instructions and docs from Google for additional guidance on how to do this.

Make sure to record the key you receive. Save this in your .env file set to zip_key.

Google Civic API

We used the Google Civic API to find state representatives from the user's address. Once you've set up the geocoding api, you can enable that key to also work for the civic api by logging into the Google Developer Console and clicking "enable APIs and Services".

How to Use the Letter Builder

  • A user can access the letter builder via one of two routes. After this point, users follow a linear flow through the app.
    • if accessing from outside of the GNC website, users begin by entering their zip code, which displays data about energy policies in their state.
    • if a user is coming to the letter builder from GNC's utility look up tool, their zip code will be pre-filled and state policies pre-populated.
  • Users can mouse over policies for a short explanation, or click for longer info.
  • On the next page, users can edit their letter's intro and conclusion, and choose policies to add to the body.
  • After perfecting their letter, users enter their address to look up their state representatives. They are prompted to choose which reps they would like to send their letter to.
  • Users can also preview their letter as a PDF if they would prefer to send it as snail mail.
  • Finally, the users can send the email (which automatically opens their mail client) and share on Facebook or Twitter.
  • Admin users have the ability to edit the information in the letter builder, including available policies and explanations, state policy data, and contact information for state offices not included in the Civic API.

Built With

Javascript, React, Node.js, Express.js, Google Geocoding API, Google Civic API, PostgreSQL, Material-UI, HTML5, CSS, Passport, react-custom-share, Font Awesome, @react-pdf/renderer

Completed Features

  • Find state by zip code
  • View summary and long info about green policies
  • Create letter, including adding policy text blocks and editing intro/conclusion text
  • Find elected reps by Address
  • Share to social media
  • Admin - edit policy text and state data
  • Admin - add/delete states, policies, state offices
  • Print letter as PDF

Next Steps

  • Integration with MailChimp for newsletter sign up

Acknowledgements

  • Thank you at Andrew Butts, Lily Richard, David Mercer Taylor, and the rest of the team at Green Neighbor Challenge for the opportunity to work on such an awesome project.
  • We would like to thank Prime Digital Academy for the opportunity to put our skills into action with a real world client project.
  • A special thanks to our instructors, Dane Smith and Kris Szafranksi, for providing us with the tools and knowledge to build this application.

Authors

Jenni Schubert , Riley Webster, Patrick Mazurek, Paul Buysse

About

The Green Neighbor Challenge letter builder helps users learn about energy policies in their state, select policies they care about, connects them to their state representatives, and helps them send an email advocating for policy change.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 95.0%
  • CSS 4.7%
  • HTML 0.3%