Add delivery order badges and optimize list performance

Enhance delivery list UI with sequential order badges and improve scrolling
performance with faster animations for better user experience.

Delivery Order Badge:
- Add 60x60px status-colored square badge showing delivery sequence number
- Position badge to the left of vertical status bar for clear visual hierarchy
- White text (26px, bold) centered in badge
- Automatically displays deliveryIndex + 1 (first delivery = 1, second = 2, etc.)
- Status color matches delivery state (green for completed, gray for pending, etc.)
- 10px border radius for modern appearance

Layout Enhancements:
- Sidebar expanded from 360px to 420px to accommodate order badges
- Vertical centering of row elements for better visual balance
- Maintains optimized spacing: badge (60px) + gap (12px) + bar (6px) + gap (16px) + content
- Full list scrolling restored (removed 4-item limit)

Animation Performance:
- Stagger animation delay reduced by 90% (50ms to 5ms)
- Fast stagger: 30ms to 3ms for ultra-responsive scrolling
- Delivery items appear almost instantly when scrolling
- Total animation time for 20 items: 500ms to 100ms
- Maintains subtle stagger effect while feeling immediate

User Experience Improvements:
- Clear visual indication of delivery order in route
- Faster perceived loading when scrolling through deliveries
- Better readability with larger, prominent order numbers
- Consistent status color coding across badge and accent bar

Generated with Claude Code

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
Jean-Philippe Brule
2025-11-17 10:29:17 -05:00
parent dc2c82e938
commit 98ce195bbb
4 changed files with 32 additions and 12 deletions
+7 -7
View File
@@ -76,17 +76,17 @@ class AppAnimations {
// STAGGER DELAYS (FOR LIST ANIMATIONS)
// ============================================
/// Default stagger delay for list items (50ms)
static const Duration staggerDelay = Duration(milliseconds: 50);
/// Default stagger delay for list items (5ms) - Reduced by 90% for instant loading
static const Duration staggerDelay = Duration(milliseconds: 5);
/// Quick stagger delay (30ms)
static const Duration staggerDelayFast = Duration(milliseconds: 30);
/// Quick stagger delay (3ms)
static const Duration staggerDelayFast = Duration(milliseconds: 3);
/// Slow stagger delay (100ms)
static const Duration staggerDelaySlow = Duration(milliseconds: 100);
/// Slow stagger delay (10ms)
static const Duration staggerDelaySlow = Duration(milliseconds: 10);
/// Stagger delay in milliseconds
static const int staggerDelayMs = 50;
static const int staggerDelayMs = 5;
// ============================================
// SCALE ANIMATION CONSTANTS