Skip to content

The Climate Town Knowledge Hub: A static site to host resources currated by the ClimateTown community

Notifications You must be signed in to change notification settings

williamtaggart97/knowledge-hub

 
 

Repository files navigation

YouTube subs Patreon

Build workflow All Contributors


The "behind the scenes" of the ClimateTown Knowledge Hub, your "one-stop shop" for important online resources in the fight against climate change!

How to suggest a resource

  • Create an issue and select "✨Resource Suggestion".
  • Fill out the form. Please adhere to the instructions.
  • Get the resource approved (or discuss it further in the issue).
  • Once approved, resource is then onboarded onto the website. Resource onboarding happens every Friday!!

Contributing

TLDR: Create an issue, or edit the content directly and make a pull request.

All contributions welcome! We embrace:

  • suggestions
  • fixing typos
  • writing content
  • helping with website development, and
  • discussing content on the Hub (check out the channels on Discord for this!)

The following sections go through how you can make different contributions. These will require you having a GitHub account.

For any discussion or questions about the Knowledge Hub, join us in the #💬knowledge-hub-discussion channel in the Climate Town Discord.

Small edits/typos

Resources data (titles, URLs, descriptions, and tags) are stored in the data/resources.yml file, which is then used to populate the resource on the website. To make small edits, you can directly edit this file or you can create an issue.

To suggest changes anywhere else in the site, you can use GitHub's search functionality to find the exact file in which to suggest them.

Resource suggestions

We're always looking to publicise awesome climate resources. Got a resource to share? The easiest way is to create an issue, filling out the "resource suggestion" form. This will create a discussion around the resource, and if it's a good fit for the Knowledge Hub, we'll add it to the site.

Site improvements

This website is powered by coders from the community. If you want to contribute to the website, please follow the following guidelines:

  • Create suggestions as issues in the repository. Discuss suggestions before submitting a pull request (unless the improvement is objectively good; e.g. performance, accessibility).
  • If you want to work on an issue, drop a comment on it (this helps prevent unnecessary doubling up of work). If someone working on an issue hasn't updated the issue in a few weeks, feel free to drop a comment of your own if you want to try it out.

Development installation

The site is built using Svelte and SvelteKit. A dev environment can be easily set up using Node and npm:

  • install Node and npm
  • git clone https://github.com/ClimateTown/knowledge-hub.git
  • cd into the cloned directory
  • npm install
  • npm run dev

OPTIONAL: Python

Some of the tools in the codebase (eg. YouTube API, JSON schema validation) use Python. For most changes to the site, Python is not required.

To set up Python:

  • install Python from here if you haven't already (minimum version 3.7)
  • create a virtual environment, then activate it (optional, but recommended)
    • python -m venv venv
    • activate the environment using either:
      • source venv/bin/activate (Linux/MacOS)
      • venv\Scripts\activate.bat (Windows)
  • pip install -r requirements.txt

This codebase uses pip-tools to manage dependencies. If you add a new dependency, you can add it to requirements.in and run pip-compile to update requirements.txt. To update your environment run pip-sync.

OPTIONAL: Loading YouTube Data

To set up the YouTube API (important for working on scripts with YouTube video scraping):

OPTIONAL: Pre-commit

This codebase uses pre-commit and pre-commit CI to run linting on code, format Python code, and generally have help with code quality.

You can either set up pre-commit locally (completely optional; it will run on every commit, aborting a commit if the pre-commit workflow fails), or you do nothing and leave it up to pre-commit CI to take care of it (where it will run on every push to GitHub, and fixes changes in PRs).

To set up pre-commit locally:

  • install the Python environment (which includes pre-commit)
  • pre-commit install to install the hooks

To run pre-commit manually (without making a commit), use pre-commit run --all-files. If you want to stop using pre-commit locally, just do pre-commit uninstall.

✨Contributors

Thanks go to these wonderful people (emoji key):

Vecko
Vecko

💻 🖋 🤔 🚧 📆
Danielle Bastien
Danielle Bastien

️️️️♿️ 💻 🚧
azebramoomoo
azebramoomoo

🖋 🎨
Jacob John Jeevan
Jacob John Jeevan

💻
Chris King
Chris King

💻
Jarrod Baniqued
Jarrod Baniqued

🖋 🐛
Nick Tutterow
Nick Tutterow

💻 🖋
GBT7
GBT7

🖋
Billy Taggart
Billy Taggart

🤔
Micahg05
Micahg05

💻
Forrest Cinelli
Forrest Cinelli

🖋
Jordan Manley
Jordan Manley

💻
cpufreak101
cpufreak101

🎨
Paweł Andrys
Paweł Andrys

💻
Matthew Caughman
Matthew Caughman

👀
LaserCar
LaserCar

🖋
Isidro Molina
Isidro Molina

💻
Christina Loiacono
Christina Loiacono

💻
River Mizell
River Mizell

🖋
monedula
monedula

🖋

This project follows the all-contributors specification. Contributions of any kind are, again, welcome!

Acknowledgements

About

The Climate Town Knowledge Hub: A static site to host resources currated by the ClimateTown community

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Svelte 50.3%
  • Python 33.9%
  • TypeScript 12.6%
  • JavaScript 1.5%
  • Other 1.7%