https://github.com/nmf-earth/nmf-app
  
  
    Understand and reduce your carbon footprint π± iOS & Android. 
    https://github.com/nmf-earth/nmf-app
  
android climate-change expo functional-programming global-warming hacktoberfest ios openfoodfacts react-native redux-toolkit sustainability typescript zero-waste
        Last synced: 7 months ago 
        JSON representation
    
Understand and reduce your carbon footprint π± iOS & Android.
- Host: GitHub
- URL: https://github.com/nmf-earth/nmf-app
- Owner: NMF-earth
- License: gpl-3.0
- Created: 2019-11-25T10:12:37.000Z (almost 6 years ago)
- Default Branch: main
- Last Pushed: 2024-12-05T15:38:34.000Z (11 months ago)
- Last Synced: 2025-04-10T06:05:51.025Z (7 months ago)
- Topics: android, climate-change, expo, functional-programming, global-warming, hacktoberfest, ios, openfoodfacts, react-native, redux-toolkit, sustainability, typescript, zero-waste
- Language: TypeScript
- Homepage: https://nmf.earth
- Size: 9.01 MB
- Stars: 525
- Watchers: 9
- Forks: 161
- Open Issues: 25
- 
            Metadata Files:
            - Readme: README.md
- Contributing: contributing.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: code_of_conduct.md
 
Awesome Lists containing this project
README
          π± NMF.earth app
Understand and reduce your carbon footprint


[](https://depfu.com/repos/github/NotMyFaultEarth/nmf-app?project_id=10243)
[](code_of_conduct.md)
[](https://github.com/climate-strike/license)
[](https://expo.io/)
Repository for the [NMF.earth](https://nmf.earth/) React Native application, built with Expo, Redux Toolkit and Typescript.
Design can be found on [Figma](https://www.figma.com/community/file/967052407514062912).
### π Data source
Carbon data comes from NMF's [carbon footprint repo](https://github.com/NMF-earth/carbon-footprint) while barcode product scanned data comes from [Open Food Facts](https://world.openfoodfacts.org/) api.
### π¦ Getting started
Installing Dependencies:
```bash
$ yarn
```
Running the app:
```bash
$ yarn start
```
For starting the app on a specific OS:
```bash
$ yarn ios | yarn android
```
### π©πΎβπ» Development
- Eslint is used in the project to enforce code style and should be configured in your [editor](https://eslint.org/docs/user-guide/integrations).
- Prettier is also used and apply automatically by eslint
- Typescript is used in the project for type-checking and should be configured in your [editor](https://github.com/Microsoft/TypeScript/wiki/TypeScript-Editor-Support).
You can check this manually by running:
```bash
$ yarn lint
```
or
```bash
$ yarn typescript
```
You can ask eslint to fix issues by running:
```bash
$ yarn lint:fix
```
### π  Testing
Use the following command to run unit tests with coverage:
```bash
$ yarn test
```
Use the following to update unit tests
```bash
$ yarn test -u
```
Use the following to run unit tests in watch mode while developing:
```bash
$ yarn test --watch
```
### π¨ Storybook
Stories (\*.story.tsx) can be automatically added to `storyLoader.js` with :
```bash
$ yarn prestorybook
```
### π Sustainable guide
To place new `.md` files inside `guides` folder or modify existing guide and then run `node scripts/generate-guides.js` to generate a new sustainable guide. Images can be used in the `.md` as follow: `` and should be place in `assets/images/guide`.
For methodology screen, just run `node scripts/generate-methodology.js` to update `methodology.json` from `methodology.md`.
For emission info screen, just run `node scripts/generate-emission-info.js` to update `emission-info.json` from `assets/emission-info/markdown/*.md`.
## π£ Translations
You can help us with translate the app with our online tool [POEditor](https://poeditor.com/join/project/0MbginCsWp). Any help is appreciate and no coding skills are needed π€
PS: please do not use send translations made by Google translate or similar.
### Generate
Run `node scripts/generate-translation-files.js` in order to create the files needed for the new language you want to add to the app.
### Manage Files
Run `node scripts/poeditor/group-translation-files.js` to generate 1 JSON file per language, with all the translation vars in it. From there, you can easily make any edit you want. When you're done, you can run `node scripts/poeditor/spread-translation-files.js` to merge your edits and spread them into all the translation files across the repo.
### π Deployment
Any tag starting with `v` will runs expo publish. During this step `app.example.json` is used to generate an `app.json` file for expo's deployment, this is done with the following script `scripts/generate-app-json.js`.
### π Build
First you need to configure `SENTRY_AUTH_TOKEN` and `SENTRY_DSN` secrets on [expo.dev](https://expo.dev/accounts/%5Baccount%5D/settings/secrets) and then define `projectId` in `app.config.js`. Then run `npm install dotenv` and place your secrets inside `.env` file that you need to create with `SENTRY_AUTH_TOKEN` and `SENTRY_DSN`, like in `.env.example`.
Run `eas build -p ios` to build for the [App Store Connect](https://appstoreconnect.apple.com) and `eas build -p android` for the [Google Play Console](https://play.google.com/console/developers).
### π¨βπ» Contribute β€οΈ
More than 40 developers have contribute to the app, thanks a lot to [them](https://github.com/NMF-earth/nmf-app/graphs/contributors)!
Have a look to [contributing.md](https://github.com/NotMyFaultEarth/nmf-app/blob/main/contributing.md) if you want to contribute!
### π Backers
A big thank you to [ChristopherΒ Gwilliams](https://github.com/encima) and to the Phelps family for their amazing contribution to the [Kickstarter](https://www.kickstarter.com/projects/pierrebresson/not-my-fault)!
### Β©οΈ Open source - licence
Repository and contributions are under [GNU General Public License v3.0](https://github.com/NotMyFaultEarth/nmf-app/blob/main/LICENSE)
        
 
 
