This is a full-stack e-commerce application with a Python backend and TypeScript frontend. The entire app was created originally from an ERD diagram and natural language prompts using Copilot. The frontend was created in the same way, using some of the design ideas in the design folder.
The hero image and product images were created by prompting ChatGPT!
The system is a modern supply chain management application with a Python backend and TypeScript frontend, comprising a REST API and a Vue.js frontend. It follows typical enterprise architecture patterns with clean separation of concerns.
- FastAPI with RESTful endpoints for all entities
- SQLite persistence using a lightweight repository pattern
- Schema migrations and seed data managed via SQL files
- Swagger/OpenAPI documentation integration
- Pydantic models with proper relationships following an ERD diagram
- Vue 3 with Composition API and TypeScript
- Vite build tool for fast development
- Pinia for state management
- Vue Router for client-side routing
- TanStack Vue Query for server state management
- Tailwind CSS for UI styling
- Docker/Docker Compose for containerization
- Optional Bicep + GitHub Actions plan for Azure deployment
erDiagram
Headquarters ||--o{ Branch: has
Branch ||--o{ Order: placed_at
Order ||--o{ OrderDetail: contains
OrderDetail ||--o{ OrderDetailDelivery: fulfilled_by
OrderDetail }|--|| Product: references
Delivery ||--o{ OrderDetailDelivery: includes
Supplier ||--o{ Delivery: provides
flowchart TD
subgraph "Frontend"
F[Vue App] --> FC[Vue Components]
FC --> FT[TypeScript]
FC --> FCSS[Tailwind CSS]
F --> FV[Vite Build Tool]
F --> FP[Pinia Store]
F --> FR[Vue Router]
end
subgraph "Backend"
B[FastAPI] --> BR[REST Routes]
BR --> BM[Pydantic Models]
B --> BS[Swagger/OpenAPI]
B --> BO[TAO Observability]
B --> R[Repositories]
end
subgraph "Data"
D[(SQLite DB\napi/data/app.db)]
end
R <--SQL queries--> D
F <--REST API--> B
- Complete REST APIs for all supply chain entities
- SQLite-backed persistence with foreign keys and indexed queries
- Declarative migrations (docs/sql/migrations) and deterministic seed data
- Detailed OpenAPI documentation
- Modern Vue.js UI with responsive design
- Containerization for consistent deployment
- Database: SQLite (file located at
api/data/app.dbby default; configurable viaDB_FILE) - Access: thin repository layer with snake_case naming throughout (Pydantic models and SQL columns)
- Migrations: SQL scripts in
api/database/migrationsexecuted in order and tracked in amigrationstable - Seeding: ordered SQL scripts in
api/database/seedto bootstrap data - Test mode: in-memory database (
:memory:) for fast and isolated tests
See the dedicated guide: docs/sqlite-integration.md.