Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mtoprak53/capstone_project_1
Calorie Counter - Calorie Logging Web App
https://github.com/mtoprak53/capstone_project_1
bootstrap database flask flask-sqlalchemy html-css jinja2 jquery postgresql python
Last synced: 17 days ago
JSON representation
Calorie Counter - Calorie Logging Web App
- Host: GitHub
- URL: https://github.com/mtoprak53/capstone_project_1
- Owner: mtoprak53
- Created: 2021-07-16T02:26:34.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-03-03T02:51:16.000Z (10 months ago)
- Last Synced: 2024-11-06T00:13:14.316Z (2 months ago)
- Topics: bootstrap, database, flask, flask-sqlalchemy, html-css, jinja2, jquery, postgresql, python
- Language: Python
- Homepage: https://calorie-counter.up.railway.app
- Size: 2.58 MB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
# Calorie Counter Web Application
The [Calorie Counter](https://calorie-counter.herokuapp.com/) web app lets users sign-up and saves their food intake logs day by day. It connects to [Fatsecret API](https://platform.fatsecret.com/api/) for detailed food nutrient information and saves them in the app's own database whenever a food log for that food item is created. Users can create their food intake logs for any day, change the date to reach earlier logs, and edit or delete already created logs for any day. Also, the daily log calculates and shows the user's daily calorie intake.
The UI is designed as two main columns where the left one is populated with control forms and buttons, and the right column is used as the informative part of the page.
There is a "most frequently eaten 20 foods" feature in the app to reach the frequent foods' info easier and directly from the local database (without external API communication).
The back-end of the app is written in Flask (Flask-SQLAlchemy, Flask-WTForms, Flask-Bcrypt) with PostgreSQL on the database side.
Jinja is used as the template system on the front-end. The
[pyfatsecret](https://pyfatsecret.readthedocs.io/en/latest/index.html) library is used to overcome too detailed authentication processes of the API communications.
The live app is deployed on Heroku servers.[The database schema](/static/images/schema.png) contains four tables.
![DB Schema](https://github.com/mtoprak53/Capstone_Project_1/blob/main/static/images/schema.png?raw=true)
# How to Build & Deploy
## Create the Python Virtual Environment (venv)
Create the virtual environment in the project directory:
### $ `python3 -m venv venv`
Start the virtual environment:
### $ `source venv/bin/activate`## Install the Required Packages
Install the pip packages required to run the app, listed in the requirements file:
### (venv) $ `pip3 install -r requirements.txt`If you encounter a installation problem with requirements.txt file:
Try requirements_noproblem.txt and install the 'psycopg2-binary' package seperately because of its incompatibility with newer python3 versions:
### (venv) $ `pip3 install -r requirements_noproblem.txt`
### (venv) $ `pip3 install psycopg2-binary`## Set up the Database
Create the database:
### (venv) $`createdb calorie_db`Create the tables:
### (venv) $`python3 seed.py`## Check the App
Start the app:
### (venv) $`flask run`View it in your browser:
### [http://localhost:5000](http://localhost:5000)```%info
IMPORTANT INFO: For API functionality, a hidden.py file containing working CONSUMER_KEY and CONSUMER_SECRET information from the Fatsecret platform is required. The API functionality can be accessed from the app's website:
```
### [https://calorie-counter.up.railway.app](https://calorie-counter.up.railway.app)Stop the virtual environment when you finish:
### (venv) $`deactivate`