Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/sarcevicantonio/kcalcalc

free calorie counting app designed for fast user interactions
https://github.com/sarcevicantonio/kcalcalc

calorie firebase firestore health svelte sveltekit

Last synced: 3 months ago
JSON representation

free calorie counting app designed for fast user interactions

Awesome Lists containing this project

README

        

# kcalCalc

A free calorie counting app made to fit my needs.

Give it a shot at [kcal-calc.vercel.app](https://kcal-calc.vercel.app)

| Mobile Day View | Item Selection | Mobile Week View |
| ------------------------------------- | ------------------------------------------------------- | ----------------------------------------- |
| ![DayView](./screenshots/DayView.png) | ![SelectItemSearch](./screenshots/SelectItemSearch.png) | ![WeekGraph](./screenshots/WeekGraph.png) |

| Desktop Unified View |
| ---------------------------------------------- |
| ![Unified View](./screenshots/UnifiedView.png) |

## Self Hosting

kcalCalc can be self-hosted for free using Firebase and a Cloud Host like Vercel.

### Setup Firebase

- Create new Firebase Project
- Create Web App
- Copy following env values for later:
- VITE_APIKEY
- VITE_AUTHDOMAIN
- VITE_PROJECTID
- VITE_STORAGEBUCKET
- VITE_MESSAGINGSENDERID
- VITE_APPID
- Enable Auth: Go to "Authentication" > "Get started" > "Google" > "Enable" > set "Project support email" field > "Save"
- Also set up your hosted app Domain under "Authentication" > "Settings" > "Authorized domains"
- Enable Firestore: Go to "Firestore Database" > "Create database" > "Start in test mode" > "Next" > set "Cloud Firestore location" field near you > "Enable"
- Setup Rules: "Firestore Database" > "Rules" > paste following
- ```js
rules_version = '2';
service cloud.firestore {
match /databases/{database}/documents {
match /Users/{userId}/{documents=**} {
allow read, write: if userId == request.auth.uid;
}
}
}
```

### Host frontend

- You can use a service like Vercel to host the frontend.
- Fork the repo and login to Vercel via GitHub
- Create a new project using the forked repo and add the env variables from above

## Development

- Copy env variables in a `.env` file
- `pnpm i`
- `pnpm dev`

- firebase emulator usage can be toggled via `VITE_USE_EMULATION=true`.
- firebase cli
- install `curl -sL https://firebase.tools | bash`
- `firebase login`
- `firebase emulators:start`

### Svelte Style Guide

- Layout: Script, Markup, Styles
- Script Layout: Imports, createEventDispatcher, export props, local state, reactive statements, functions.
- Hints that you component is too complicated:
- If you feel like you want to organize script differently
- ~6 Levels of Indentation max
- ~300LOC max