Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/dvelasquez/carbon-tools

A set of CO2 footprint tools to measure the impact of the code we ship
https://github.com/dvelasquez/carbon-tools

Last synced: about 2 months ago
JSON representation

A set of CO2 footprint tools to measure the impact of the code we ship

Awesome Lists containing this project

README

        

# Carbon Tools
[![lerna](https://img.shields.io/badge/maintained%20with-lerna-cc00ff.svg)](https://lerna.js.org/)

This is a [mono-repository/multi-package](https://dev.to/tallyb/six-blind-people-and-a-monorepo-1n49) built with Lerna & TypeScript.

## Contents

1. [bytes-to-co2:](./packages/bytes-to-co2) A library that estimates the CO2 released to the atmosphere based on the transferred byte size.
2. [co2-extension](./packages/co2-extension): A Chrome (for now) that shows the amount of CO2 released by visiting the current page.
3. [lighthouse-plugin-co2](./packages/lighthouse-plugin-co2): A Lighthouse Plugin that calculates the CO2 of all the data transferred by a page.
4. [co2-data](./packages/co2-data): A small library with information of carbon intensities by country.

## Using as a dependency

For now, we are only exposing as libraries [co2-data](https://www.npmjs.com/package/co2-data) and
[bytes-to-co2](https://www.npmjs.com/package/bytes-to-co2), which you can install in your project using:

- `yarn add bytes-to-co2` or `npm i bytes-to-co2`
- `yarn add co2-data` or `npm i co2-data`

## Development - Getting started

Project supports NodeJS >= v12.x

1. Clone the project `git clone https://github.com/dvelasquez/carbon-tools.git`
2. Run `yarn` to install the dev dependencies
3. Use `pnpm lerna:build` to build all the libraries
4. Use `pnpm lint` to lint files and catch issues with the code styling, or possible code errors
5. Use `pnpm test` to run Node TAP tests