Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/spencerlepine/quickcart
A grocery product catalog for budgeting a shopping list stored in the cloud. Built with React.js, Node.js, Material UI, and Firebase.
https://github.com/spencerlepine/quickcart
firebase javascript material-ui nodejs openfoodfacts react reactjs spoonacular
Last synced: about 2 months ago
JSON representation
A grocery product catalog for budgeting a shopping list stored in the cloud. Built with React.js, Node.js, Material UI, and Firebase.
- Host: GitHub
- URL: https://github.com/spencerlepine/quickcart
- Owner: spencerlepine
- Created: 2021-03-17T23:13:49.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2023-12-10T01:19:11.000Z (about 1 year ago)
- Last Synced: 2024-05-04T00:07:09.164Z (8 months ago)
- Topics: firebase, javascript, material-ui, nodejs, openfoodfacts, react, reactjs, spoonacular
- Language: JavaScript
- Homepage: https://www.youtube.com/watch?v=2YrizGT_2xA
- Size: 28.6 MB
- Stars: 3
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# [QuickCart](https://grocery-client-sl.herokuapp.com/) [![Build Status](https://github.com/spencerlepine/quickcart/actions/workflows/main.yml/badge.svg?branch=master)](https://github.com/spencerlepine/quickcart/actions/workflows/main.yml) ![Inactive Badge](./whitepaper/images/inactive.svg)
Create and store weekly grocery shopping lists. Find real products via search or barcode scan, view nutrition facts, or upload your own.
![React](https://img.shields.io/badge/react-%2320232a.svg?style=for-the-badge&logo=react&logoColor=%2361DAFB) ![Firebase](https://img.shields.io/badge/firebase-orange.svg?style=for-the-badge&logo=firebase&logoColor=white) ![Heroku](https://img.shields.io/badge/heroku-%23430098.svg?style=for-the-badge&logo=heroku&logoColor=white)
![Demo GIF](./client/src/assets/images/demo.gif)
## 🎥 Demo Video + Project Walk-through
[![Youtube Video](./whitepaper/images/THUMBNAIL-smaller.png)](https://www.youtube.com/watch?v=2YrizGT_2xA)
## 🎯 Project Overview
A grocery product catalog to assist budgeting and managing a shopping list stored in the cloud.- Designed a **Firebase Cloud Firestore NoSQL** database managing user records, grocery product catalogs, and cart purchase histories
- Organized state management for products, account information, and carts with Context hooks also persisted in the database.
- Integrated Firebase **Authentication** to assist storing user unique shopping lists, along with customized product records.
- Created a clean and modern user experience with **React/MaterialUI** following a wireframe and site-wide color theme.
- Implemented barcode scanning and external records from the **Spoonacular** + **OpenFoodFacts** API to onboard new products## 📦 Technologies:
- [React](https://reactjs.org/)
- [Firebase](https://firebase.google.com/)
- [React Testing Libary](https://testing-library.com/)
- [Material-UI](https://material-ui.com/)
- [OpenFoodFacts](https://world.openfoodfacts.org)
- [Google CSE](https://cse.google.com)
- [Spoonacular](https://spoonacular.com/food-api/docs)
- [Heroku](https://www.heroku.com/) (for hosting frontend)## 🏗️ Architecture
![Architecture](./whitepaper/images/quickcart-architecture-diagram.jpg)
## 🌟 Features:
- Browse grocery products records served from the Firestore database
- Save products to your cart, always persisted in the cloud.
- Analyze the cart to identify empty categories
- Customized product records and create a personal list
- Create an account to access your list anywhere
- Scan a bar code to upload a product pulled from Spoonacular or OpenFoodFacts
- View a history of transaction receipts previous from shopping lists
- Save product images with a convient image searching pop-up connected to Google CSE![Demo Screenshot](./client/src/assets/images/demo_transparent.png)
![Cart Feature Screenshot](./client/src/assets/images/cart-screenshot.png)
![Search Feature Screenshot](./client/src/assets/images/search-screenshot.png)
![Scan Feature Screenshot](./client/src/assets/images/scan-upc.png)
![Analyzer Feature Screenshot](./client/src/assets/images/analyzer-screenshot.png)
![Customize Feature Screenshot](./client/src/assets/images/customize-product.png)
![Saved Feature Screenshot](./client/src/assets/images/saved-screenshot.png)## Deployment
![Architecture](./whitepaper/images/quickcart-deployment-diagram.jpg)
## ⚙️ Local Development
```sh
$ cp .env.sample .env
$ npm install
$ npm run dev
```