Implement product variations, enhanced order workflow, mobile responsiveness, and product import system
## Product Variations System - Add ProductVariation model with quantity-based pricing (1 for £10, 2 for £19, 3 for £25) - Complete CRUD operations for product variations - Enhanced ProductService to include variations in all queries - Updated OrderItem to support ProductVariationId for variation-based orders - Graceful error handling for duplicate quantity constraints - Admin interface with variations management (Create/Edit/Delete) - API endpoints for programmatic variation management ## Enhanced Order Workflow Management - Redesigned OrderStatus enum with clear workflow states (Accept → Packing → Dispatched → Delivered) - Added workflow tracking fields (AcceptedAt, PackingStartedAt, DispatchedAt, ExpectedDeliveryDate) - User tracking for accountability (AcceptedByUser, PackedByUser, DispatchedByUser) - Automatic delivery date calculation (dispatch date + working days, skips weekends) - On Hold workflow for problem resolution with reason tracking - Tab-based orders interface focused on workflow stages - One-click workflow actions from list view ## Mobile-Responsive Design - Responsive orders interface: tables on desktop, cards on mobile - Touch-friendly buttons and spacing for mobile users - Horizontal scrolling tabs with condensed labels on mobile - Color-coded status borders for quick visual recognition - Smart text switching based on screen size ## Product Import/Export System - CSV import with product variations support - Template download with examples - Export existing products to CSV - Detailed import results with success/error reporting - Category name resolution (no need for GUIDs) - Photo URLs import support ## Enhanced Dashboard - Product variations count and metrics - Stock alerts (low stock/out of stock warnings) - Order workflow breakdown (pending, accepted, dispatched counts) - Enhanced layout with more detailed information ## Technical Improvements - Fixed form binding issues across all admin forms - Removed external CDN dependencies for isolated deployment - Bot Wizard form with auto-personality assignment - Proper authentication scheme configuration (Cookie + JWT) - Enhanced debug logging for troubleshooting ## Self-Contained Deployment - All external CDN references replaced with local libraries - Ready for air-gapped/isolated network deployment - No external internet dependencies 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@@ -16,10 +16,11 @@
|
||||
</div>
|
||||
<div class="card-body">
|
||||
<h4 class="card-title">@ViewData["TotalOrders"]</h4>
|
||||
<small>@ViewData["PendingOrders"] pending • @ViewData["ShippedOrders"] shipped</small>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<div class="col-md-3">
|
||||
<div class="card text-white bg-success mb-3">
|
||||
<div class="card-header">
|
||||
@@ -27,21 +28,23 @@
|
||||
</div>
|
||||
<div class="card-body">
|
||||
<h4 class="card-title">@ViewData["TotalProducts"]</h4>
|
||||
<small>@ViewData["TotalVariations"] variations • @ViewData["TotalStock"] in stock</small>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<div class="col-md-3">
|
||||
<div class="card text-white bg-info mb-3">
|
||||
<div class="card-header">
|
||||
<i class="fas fa-tags"></i> Total Categories
|
||||
<i class="fas fa-tags"></i> Categories
|
||||
</div>
|
||||
<div class="card-body">
|
||||
<h4 class="card-title">@ViewData["TotalCategories"]</h4>
|
||||
<small>Active categories</small>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<div class="col-md-3">
|
||||
<div class="card text-white bg-warning mb-3">
|
||||
<div class="card-header">
|
||||
@@ -49,6 +52,48 @@
|
||||
</div>
|
||||
<div class="card-body">
|
||||
<h4 class="card-title">£@ViewData["TotalRevenue"]</h4>
|
||||
<small>From completed orders</small>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="row mb-3">
|
||||
<div class="col-md-3">
|
||||
<div class="card text-white bg-danger mb-3">
|
||||
<div class="card-header">
|
||||
<i class="fas fa-exclamation-triangle"></i> Stock Alerts
|
||||
</div>
|
||||
<div class="card-body">
|
||||
<h4 class="card-title">@ViewData["LowStockProducts"]</h4>
|
||||
<small>@ViewData["OutOfStockProducts"] out of stock</small>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="col-md-9">
|
||||
<div class="card">
|
||||
<div class="card-header">
|
||||
<h5><i class="fas fa-list"></i> Product Variations Summary</h5>
|
||||
</div>
|
||||
<div class="card-body">
|
||||
@if ((int)ViewData["TotalVariations"] > 0)
|
||||
{
|
||||
<div class="alert alert-success">
|
||||
<i class="fas fa-check-circle"></i>
|
||||
<strong>@ViewData["TotalVariations"] product variations</strong> have been configured across your catalog.
|
||||
Customers can now choose quantity-based pricing options!
|
||||
</div>
|
||||
}
|
||||
else
|
||||
{
|
||||
<div class="alert alert-info">
|
||||
<i class="fas fa-info-circle"></i>
|
||||
No product variations configured yet.
|
||||
<a href="@Url.Action("Index", "Products")" class="alert-link">Add variations</a>
|
||||
to offer quantity-based pricing (e.g., 1 for £10, 2 for £19, 3 for £25).
|
||||
</div>
|
||||
}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
Reference in New Issue
Block a user