Skip to content

chihacknight/decarbonize-my-state

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Apr 6, 2022
105ce12 Β· Apr 6, 2022
Feb 4, 2022
Mar 25, 2022
Apr 6, 2022
Feb 11, 2022
Feb 4, 2022
Feb 4, 2022
Feb 4, 2022
Feb 4, 2022
Mar 17, 2022
Feb 4, 2022
Feb 4, 2022
Feb 4, 2022
Mar 23, 2022
Feb 4, 2022
Feb 4, 2022
Mar 28, 2022
Mar 28, 2022
Feb 4, 2022

Repository files navigation

State by State Decarbonization

Chi Hack Night data visualization project to measure the state and progress of decarbonization for all States in the USA.

This is a Gatsby app built on top of the DataMade Gatsby starter template, which was adapted from the default Gatsby starter repo.

πŸ’Ύ Requirements

πŸš€ Quick start

  1. Grab the repo:

    git clone git@github.com:chihacknight/state-by-state-decarbonization.git
    cd state-by-state-decarbonization
  2. Start developing

    docker-compose up --build

    Your site should now be up and running at http://localhost:8000!

Dependencies

This starter has a minimal number of dependencies in order to stay lean, but you'll likely want to add more to suit your needs. To add a dependency, run:

docker-compose run --rm app add <dependency name> --save

To remove a dependency:

docker-compose run --rm app remove <dependency name>

Testing & syntax linting

When you run docker-compose up locally, ESLint makes sure you're following the right JS style conventions and not importing or exporting anything extraneously. If you are, the build will fail.

If you want to check the linter on its own you can run:

docker-compose run --rm app run test

To auto-fix, run this command with --fix like so:

docker-compose run --rm app run test --fix

Data processing

All data that appears on the frontend of this site should come directly from a file in data/finalβ€”for more on that line of thinking, see this guide to data handling in Gatsby. The data processing pipeline for this project lives in data/ and follows DataMade's data making guidelines. As these files are relatively small, we keep both raw and final data under version control.

To recreate the data, run:

cd data
docker-compose up --build

πŸ€– What's inside?

Taken from gatsby-starter-default

A quick look at the top-level files and directories you'll see in a Gatsby project.

.
β”œβ”€β”€ .github/workflows
β”œβ”€β”€ src
β”œβ”€β”€ static
β”œβ”€β”€ .gitignore
β”œβ”€β”€ .prettierrc
β”œβ”€β”€ gatsby-browser.js
β”œβ”€β”€ gatsby-config.js
β”œβ”€β”€ gatsby-node.js
β”œβ”€β”€ gatsby-ssr.js
β”œβ”€β”€ LICENSE
β”œβ”€β”€ package-lock.json
β”œβ”€β”€ package.json
└── README.md
  1. /.github/workflows: This directory contains the project's Github Actions. By default, test.yml runs a linter.

  2. /src: This directory will contain all of the code related to what you will see on the front-end of your site (what you see in the browser) such as your site header or a page template. src is a convention for β€œsource code”.

  3. /static: This directory contains files you'll need to access directly on the frontend, like images for social cards.

  4. .eslintrc.js: This is a configuration file for ESLint, a Javascript linter.

  5. .gitignore: This file tells git which files it should not track / not maintain a version history for.

  6. gatsby-browser.js: This file is where Gatsby expects to find any usage of the Gatsby browser APIs (if any). These allow customization/extension of default Gatsby settings affecting the browser.

  7. gatsby-config.js: This is the main configuration file for a Gatsby site. This is where you can specify information about your site (metadata) like the site title and description, which Gatsby plugins you’d like to include, etc. (Check out the config docs for more detail).

  8. gatsby-node.js: This file is where Gatsby expects to find any usage of the Gatsby Node APIs (if any). These allow customization/extension of default Gatsby settings affecting pieces of the site build process.

  9. gatsby-ssr.js: This file is where Gatsby expects to find any usage of the Gatsby server-side rendering APIs (if any). These allow customization of default Gatsby settings affecting server-side rendering.

  10. LICENSE: Gatsby is licensed under the MIT license.

  11. package.json: A manifest file for Node.js projects, which includes things like metadata (the project’s name, author, etc). This manifest is how npm knows which packages to install for your project.

  12. README.md: A text file containing useful reference information about your project.

πŸŽ“ Learning Gatsby

Looking for more guidance? Full documentation for Gatsby lives on the website. Here are some places to start:

  • For most developers, we recommend starting with our in-depth tutorial for creating a site with Gatsby. It starts with zero assumptions about your level of ability and walks through every step of the process.

  • To dive straight into code samples, head to our documentation. In particular, check out the Guides, API Reference, and Advanced Tutorials sections in the sidebar.

πŸ’« Deploy

DataMade deploys static sites using Netlify. This project's staging URL is state-decarbonize.netlify.app.