Commit Graph

4 Commits

Author SHA1 Message Date
Claude
fa43fddcbd feat: Rewrite InventoryWizard with comprehensive field support
Complete rewrite following the established pattern from Recipe, Customer,
and Supplier wizards. Key improvements:

- Reduced from 3 steps to 1 streamlined comprehensive step
- Removed all duplicate "Continuar" buttons
- Added validate prop with required field checks (name, unitOfMeasure, productType)
- Real-time data sync with parent wizard using useEffect
- Auto-generation of SKU from name (SKU-XXX-1234)
- Added ALL 44 backend fields from research:
  * Required: name, unitOfMeasure, productType
  * Basic: sku, barcode, ingredient/product category, brand, description
  * Pricing: averageCost, lastPurchasePrice, standardCost, sellingPrice, minimumPrice
  * Inventory Management: lowStockThreshold, reorderPoint, reorderQuantity,
    maxStockLevel, leadTimeDays
  * Product Info: packageSize, shelfLifeDays, displayLifeHours,
    storageTempMin/Max
  * Storage & Handling: storageInstructions, handlingInstructions, isPerishable
  * Supplier Info: preferredSupplierId, supplierProductCode
  * Quality & Compliance: allergenInfo, nutritionalInfo, certifications
  * Physical Properties: weight, volume, dimensions, color
  * Status & Tracking: isActive, trackByLot, trackByExpiry, allowNegativeStock
  * Metadata: notes, tags, customFields
- Organized fields using AdvancedOptionsSection for progressive disclosure
- Added tooltips for complex fields using existing Tooltip component
- Dynamic category selection based on product type
- Comprehensive validation for required fields only
2025-11-10 07:41:26 +00:00
Claude
89e672cb4f fix: Add dark mode support to all wizard input fields
- Added bg-[var(--bg-primary)] and text-[var(--text-primary)] CSS variables
- Fixes white background + white text issue in dark mode
- Applied to all input, select, and textarea elements across 8 wizards

Wizards fixed:
- InventoryWizard
- CustomerWizard
- SupplierWizard
- RecipeWizard
- EquipmentWizard
- QualityTemplateWizard
- TeamMemberWizard
- CustomerOrderWizard

(SalesEntryWizard was already fixed in previous commit)

This completes the dark mode UI improvements (High Priority item).
All form inputs now properly support dark mode with correct contrast.
2025-11-09 21:25:36 +00:00
Claude
c103ed6efc feat: Improve main entry point and inventory wizard UI/UX
Main Entry Point (ItemTypeSelector):
- Moved Registro de Ventas to first position (most common)
- Changed icon from DollarSign to Euro icon
- Fixed alignment between icons and text (items-center instead of items-start)
- Improved spacing between title and subtitle (mb-0.5, mt-1)
- Better visual centering of all elements

Inventory Wizard (TypeSelectionStep):
- Enhanced selection UI with ring and shadow when selected
- Better color feedback (10% opacity background, ring-2)
- Dynamic icon color (primary when selected, tertiary when not)
- Dynamic title color (primary when selected)
- Improved spacing between title and description (mb-3, mt-3)
- Added hover effects (shadow-lg, -translate-y-0.5)
- Better visual distinction for selected state

All changes improve visual feedback and user experience.
2025-11-09 21:01:27 +00:00
Claude
1eacfc8e64 feat: Add JTBD-driven Unified Add Wizard system
Implemented a comprehensive unified wizard system to consolidate all "add new content"
actions into a single, intuitive, step-by-step guided experience based on Jobs To Be Done
(JTBD) methodology.

## What's New

### Core Components
- **UnifiedAddWizard**: Main orchestrator component that routes to specific wizards
- **ItemTypeSelector**: Beautiful visual card-based selection for 9 content types
- **9 Individual Wizards**: Step-by-step flows for each content type

### Priority Implementations (P0)
1. **SalesEntryWizard**  (MOST CRITICAL)
   - Manual entry with dynamic product lists and auto-calculated totals
   - File upload placeholder for CSV/Excel bulk import
   - Critical for small bakeries without POS systems

2. **InventoryWizard**
   - Type selection (ingredient vs finished product)
   - Context-aware forms based on inventory type
   - Optional initial lot entry

### Placeholder Wizards (P1/P2)
- Customer Order, Supplier, Recipe, Customer, Quality Template, Equipment, Team Member
- Proper structure in place for incremental enhancement

### Dashboard Integration
- Added prominent "Agregar" button in dashboard header
- Opens wizard modal with visual type selection
- Auto-refreshes dashboard after wizard completion

### Design Highlights
- Mobile-first responsive design (full-screen on mobile, modal on desktop)
- Touch-friendly with 44px+ touch targets
- Follows existing color system and design tokens
- Progressive disclosure to reduce cognitive load
- Accessibility-compliant (WCAG AA)

## Documentation

Created comprehensive documentation:
- `JTBD_UNIFIED_ADD_WIZARD.md` - Full JTBD analysis and research
- `WIZARD_ARCHITECTURE_DESIGN.md` - Technical design and specifications
- `UNIFIED_WIZARD_IMPLEMENTATION_SUMMARY.md` - Implementation guide

## Files Changed

- New: `frontend/src/components/domain/unified-wizard/` (15 new files)
- Modified: `frontend/src/pages/app/DashboardPage.tsx` (added wizard integration)

## Next Steps

- [ ] Connect wizards to real API endpoints (currently mock/placeholder)
- [ ] Implement full CSV upload for sales entry
- [ ] Add comprehensive form validation
- [ ] Enhance P1 priority wizards based on user feedback

## JTBD Alignment

Main Job: "When I need to expand or update my bakery operations, I want to quickly add
new resources to my management system, so I can keep my business running smoothly."

Key insights applied:
- Prioritized sales entry (most bakeries lack POS)
- Mobile-first (bakery owners are on their feet)
- Progressive disclosure (reduce overwhelm)
- Forgiving interactions (can go back, save drafts)
2025-11-09 08:40:01 +00:00