• Add full edit functionality for groceries with modal support
• Standardize delete confirmations across all components using ConfirmDeleteModal
• Implement complete shopping event edit functionality:
  - Create EditShoppingEvent component with full form capabilities
  - Add missing backend PUT endpoint for shopping events
  - Support editing all event data (shop, date, groceries, amounts, prices, notes)
• Add inline grocery edit functionality in shopping event forms:
  - Allow editing grocery items within add/edit forms
  - Load selected items back into input fields for modification
• Fix date timezone issues in edit forms to prevent date shifting
• Remove non-functional "View Details" button in favor of working Edit button
• Enhance user experience with consistent edit/delete patterns across the app
Breaking changes: None
Backend: Added PUT /shopping-events/{id} and DELETE /shopping-events/{id} endpoints
Frontend: Complete edit workflow for all entities with improved UX
		
	
Grocery Tracker
A web application for tracking grocery prices and shopping events. Built with FastAPI (Python) backend and React (TypeScript) frontend.
Features
- Grocery Management: Add, edit, and track grocery items with prices, categories, and organic status
- Shop Management: Manage different shops with locations
- Shopping Events: Record purchases with multiple groceries and amounts
- Price Tracking: Monitor price changes over time
- Modern UI: Clean, responsive interface built with React and Tailwind CSS
Architecture
Technology Stack
Backend (Python):
- FastAPI - Modern, fast web framework
- SQLAlchemy - SQL toolkit and ORM
- PostgreSQL - Relational database
- Pydantic - Data validation and settings management
- Alembic - Database migrations
Frontend (React):
- React 18 with TypeScript
- React Router - Client-side routing
- Tailwind CSS - Utility-first CSS framework
- Axios - HTTP client for API calls
- React Hook Form - Form handling
Component Communication
┌─────────────────┐    HTTP/REST API    ┌─────────────────┐    SQL Queries    ┌─────────────────┐
│   React         │ ←─────────────────→ │   FastAPI       │ ←───────────────→ │   PostgreSQL    │
│   Frontend      │     JSON requests   │   Backend       │   SQLAlchemy ORM  │   Database      │
│   (Port 3000)   │     JSON responses  │   (Port 8000)   │                   │   (Port 5432)   │
└─────────────────┘                     └─────────────────┘                   └─────────────────┘
Data Model
Groceries
- id: Primary key
- name: Grocery name
- price: Current price
- category: Food category
- organic: Boolean flag
- weight: Weight/volume
- weight_unit: Unit (g, kg, ml, l, piece)
Shops
- id: Primary key
- name: Shop name
- city: Location city
- address: Optional full address
Shopping Events
- id: Primary key
- shop_id: Foreign key to shops
- date: Purchase date
- total_amount: Optional total cost
- notes: Optional notes
- groceries: Many-to-many relationship with amounts
Setup Instructions
Prerequisites
- Python 3.8+ - For the backend
- Node.js 16+ - For the frontend
- PostgreSQL - Database
Backend Setup
- 
Navigate to backend directory: cd backend
- 
Create virtual environment: python3 -m venv venv source venv/bin/activate # On Windows: venv\Scripts\activate
- 
Install dependencies: pip install -r requirements.txt
- 
Setup database: # Create PostgreSQL database createdb grocery_tracker # Copy environment variables cp env.example .env # Edit .env with your database credentials nano .env
- 
Run database migrations: alembic upgrade head # After setting up alembic
- 
Start the backend server: uvicorn main:app --reloadThe API will be available at http://localhost:8000API docs athttp://localhost:8000/docs
Frontend Setup
- 
Navigate to frontend directory: cd frontend
- 
Install dependencies: npm install
- 
Start the development server: npm startThe app will be available at http://localhost:3000
API Endpoints
Groceries
- GET /groceries/- List all groceries
- POST /groceries/- Create new grocery
- GET /groceries/{id}- Get specific grocery
- PUT /groceries/{id}- Update grocery
- DELETE /groceries/{id}- Delete grocery
Shops
- GET /shops/- List all shops
- POST /shops/- Create new shop
- GET /shops/{id}- Get specific shop
Shopping Events
- GET /shopping-events/- List all shopping events
- POST /shopping-events/- Create new shopping event
- GET /shopping-events/{id}- Get specific shopping event
Statistics
- GET /stats/categories- Category spending statistics
- GET /stats/shops- Shop visit statistics
Usage
- Add Shops: Start by adding shops where you buy groceries
- Add Groceries: Create grocery items with prices and categories
- Record Purchases: Use the "Add Purchase" form to record shopping events
- Track Prices: Monitor how prices change over time
- View Statistics: Analyze spending patterns by category and shop
Development
Running Tests
Backend:
cd backend
pytest
Frontend:
cd frontend
npm test
Database Migrations
cd backend
alembic revision --autogenerate -m "Description"
alembic upgrade head
Docker Deployment
Create docker-compose.yml for easy deployment:
version: '3.8'
services:
  db:
    image: postgres:15
    environment:
      POSTGRES_DB: grocery_tracker
      POSTGRES_USER: grocery_user
      POSTGRES_PASSWORD: your_password
    volumes:
      - postgres_data:/var/lib/postgresql/data
    ports:
      - "5432:5432"
  backend:
    build: ./backend
    ports:
      - "8000:8000"
    depends_on:
      - db
    environment:
      DATABASE_URL: postgresql://grocery_user:your_password@db:5432/grocery_tracker
  frontend:
    build: ./frontend
    ports:
      - "3000:3000"
    depends_on:
      - backend
volumes:
  postgres_data:
Contributing
- Fork the repository
- Create a feature branch
- Make changes
- Add tests
- Submit a pull request
License
MIT License
Description
				
					Languages
				
				
								
								
									TypeScript
								
								75.9%
							
						
							
								
								
									Python
								
								22.8%
							
						
							
								
								
									Shell
								
								0.4%
							
						
							
								
								
									Dockerfile
								
								0.4%
							
						
							
								
								
									HTML
								
								0.3%
							
						
							
								
								
									Other
								
								0.1%