feat(data-entry): Bulk Receipt Upload cu Mobile UX Android Nativ

## Funcționalități Principale

### Bulk Upload & Processing
- Drag & drop pentru upload bonuri multiple oriunde pe pagină
- Batch processing cu job queue și worker pool
- Real-time updates via SSE (Server-Sent Events) cu fallback polling
- Duplicate detection via SHA-256 file hash
- Auto-retry pentru job-uri failed
- Cancel individual jobs sau batch complet

### Mobile UX - Android Native Style
- Top bar fixă cu hamburger, titlu centrat, acțiuni (search/filter)
- Bottom navigation cu 4 tab-uri (Bonuri, Upload, Rapoarte, Setări)
- FAB (Floating Action Button) cu hide/show on scroll
- Filter chips orizontal scrollabile
- Selecție multiplă prin long-press (500ms)
- Select All + Bulk Delete cu confirmare
- Layout Android pentru Create/Edit/View bon (Gmail compose style)

### Bug Fixes
- Refresh individual via SSE în loc de refresh total pagină
- Bonurile cu eroare OCR rămân vizibile pentru editare manuală
- Afișare nume fișier original pentru toate bonurile
- Upload stabil pe mobil (fix race condition File API)
- Păstrare ordine bonuri la refresh (nu se reordonează)

### Backend
- SSE endpoint pentru status updates real-time
- Bulk delete endpoint cu partial success
- Auto-cleanup bonuri failed după 7 zile
- Batch model cu tracking complet

### Testing
- E2E tests cu Playwright
- Unit tests pentru bulk upload, auto-create, cleanup

## Commits Squashed: 43 user stories (US-001 → US-043)
## Branch: ralph/bulk-receipt-upload
## Timp dezvoltare: ~3 zile (Ralph autonomous)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
Claude Agent
2026-01-12 08:33:17 +00:00
parent b4a226409c
commit 7b3541403f
53 changed files with 15810 additions and 196 deletions

67
scripts/ralph/prompt.md Normal file
View File

@@ -0,0 +1,67 @@
# Ralph Iteration Prompt Template
Acest fișier conține template-ul de prompt folosit de Ralph pentru fiecare iterație.
## Context
Ralph citește `prd.json` și selectează următoarea user story neprocesată (by priority).
Apoi lansează Claude cu un prompt care include:
1. Story ID și titlu
2. Acceptance criteria complete
3. Technical notes
4. CSS rules din PRD
## Cum funcționează
### Signals de la Claude:
- **STORY_PASSED** - Toate criteriile sunt îndeplinite, Ralph marchează story ca passed și commit-uiește
- **STORY_BLOCKED: <reason>** - Story-ul nu poate fi completat, Ralph oprește loop-ul
### Flow per iterație:
```
1. Ralph citește prd.json
2. Selectează story cu priority minim care are passes=false
3. Generează prompt cu detaliile story-ului
4. Rulează: claude -p "<prompt>"
5. Analizează output:
- STORY_PASSED → mark passed, git commit, next iteration
- STORY_BLOCKED → log reason, stop loop
- Altceva → continue iteration (Claude încă lucrează)
6. Sleep 2s, repeat
```
## CSS Rules Reminder
Fiecare prompt include CSS rules din PRD pentru că sunt critice:
```
IMPORTANT CSS RULES:
- NEVER use hardcoded values - always use design tokens
- Check docs/DESIGN_TOKENS.md before writing CSS
- Test in BOTH light and dark mode
- NEVER use :deep() in components
```
## Manual Override
Dacă Ralph se blochează, poți:
1. Edita `prd.json` manual pentru a marca stories ca passed
2. Adăuga notes explicative
3. Relansa Ralph cu `./ralph.sh`
## Monitorizare
```bash
# Vezi progress
cat scripts/ralph/prd.json | jq '.userStories[] | {id, title, passes}'
# Vezi log curent
tail -f scripts/ralph/progress.txt
# Vezi toate logurile
ls -la scripts/ralph/logs/
```