Aggiunge SOP iniziale del progetto
Documento di specifiche per BitePlan: meal planner settimanale, convertitore peso crudo/cotto e lista della spesa. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
160
sop.md
Normal file
160
sop.md
Normal file
@@ -0,0 +1,160 @@
|
|||||||
|
# SOP — BitePlan (Vue 3 + Vite → Capacitor Android)
|
||||||
|
|
||||||
|
## Scope
|
||||||
|
|
||||||
|
App mobile-first con tre funzionalità:
|
||||||
|
|
||||||
|
1. **Meal Planner** — pianificazione settimanale (7 giorni × 3 pasti: colazione, pranzo, cena). Ogni pasto contiene una lista di voci testuali liberamente modificabili.
|
||||||
|
2. **Conversione crudo/cotto** — calcolo del peso cotto a partire dal peso crudo (e viceversa) tramite coefficienti di resa definiti in un JSON interno.
|
||||||
|
3. **Lista della spesa** — checklist con aggiunta, spunta e rimozione elementi.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Stack tecnologico
|
||||||
|
|
||||||
|
| Livello | Scelta |
|
||||||
|
|---|---|
|
||||||
|
| Frontend | Vue 3 + Vite |
|
||||||
|
| Stato | Composables (no store) |
|
||||||
|
| Persistenza | LocalStorage |
|
||||||
|
| UI | CSS base mobile-first |
|
||||||
|
| Mobile (fase successiva) | Capacitor Android |
|
||||||
|
| Build riproducibile (opzionale) | Docker |
|
||||||
|
|
||||||
|
Sviluppo iniziale: `npm run dev` + Chrome DevTools modalità mobile.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Struttura progetto
|
||||||
|
|
||||||
|
```
|
||||||
|
src/
|
||||||
|
├── pages/
|
||||||
|
│ ├── MealPlanner.vue
|
||||||
|
│ ├── Converter.vue
|
||||||
|
│ └── ShoppingList.vue
|
||||||
|
├── components/
|
||||||
|
│ ├── BottomNav.vue
|
||||||
|
│ ├── MealCard.vue
|
||||||
|
│ └── CheckboxItem.vue
|
||||||
|
├── data/
|
||||||
|
│ └── conversions.json
|
||||||
|
├── utils/
|
||||||
|
│ ├── conversion.js
|
||||||
|
│ └── storage.js
|
||||||
|
└── App.vue
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Fase 1 — Setup
|
||||||
|
|
||||||
|
```bash
|
||||||
|
npm create vue@latest biteplan
|
||||||
|
cd biteplan
|
||||||
|
npm install
|
||||||
|
npm run dev
|
||||||
|
```
|
||||||
|
|
||||||
|
Test mobile: Chrome → F12 → viewport 360×640.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Fase 2 — Meal Planner
|
||||||
|
|
||||||
|
**Struttura dati**
|
||||||
|
|
||||||
|
```js
|
||||||
|
{
|
||||||
|
lunedi: { colazione: [], pranzo: [], cena: [] },
|
||||||
|
martedi: { ... }
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**Funzionalità**
|
||||||
|
- Aggiungere/rimuovere voci per ogni pasto
|
||||||
|
- Visualizzare l'intera settimana
|
||||||
|
- Salvataggio automatico su LocalStorage
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Fase 3 — Conversione crudo/cotto
|
||||||
|
|
||||||
|
**JSON** — `src/data/conversions.json`
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"pollo": { "forno": { "yield": 0.75 }, "padella": { "yield": 0.70 } },
|
||||||
|
"riso": { "bollito": { "yield": 2.5 } }
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
`yield = peso_cotto / peso_crudo`
|
||||||
|
|
||||||
|
**Funzioni** — `src/utils/conversion.js`
|
||||||
|
|
||||||
|
```js
|
||||||
|
export const rawToCooked = (food, method, raw, db) => raw * db[food][method].yield
|
||||||
|
export const cookedToRaw = (food, method, cooked, db) => cooked / db[food][method].yield
|
||||||
|
```
|
||||||
|
|
||||||
|
**UX**: ricerca testuale sull'alimento → selezione alimento+metodo → input grammi → risultato in tempo reale.
|
||||||
|
|
||||||
|
Esempio: 140 g pollo crudo → 105 g cotti al forno.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Fase 4 — Lista della spesa
|
||||||
|
|
||||||
|
**Struttura dati**
|
||||||
|
|
||||||
|
```js
|
||||||
|
[{ id, name, checked }]
|
||||||
|
```
|
||||||
|
|
||||||
|
**Funzionalità**: aggiungi, spunta, elimina, svuota lista.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Fase 5 — UI Mobile
|
||||||
|
|
||||||
|
Navigazione bottom bar: Pasti | Converti | Spesa.
|
||||||
|
|
||||||
|
Linee guida: bottoni min 44px, input semplici, una funzione per schermata.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Fase 6 — Android (Capacitor)
|
||||||
|
|
||||||
|
```bash
|
||||||
|
npm install @capacitor/core @capacitor/cli
|
||||||
|
npx cap init
|
||||||
|
npx cap add android
|
||||||
|
npm run build && npx cap sync && npx cap run android
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Fase 7 — Docker (opzionale)
|
||||||
|
|
||||||
|
Pipeline: install → build frontend → cap sync → gradle build APK.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Fasi future
|
||||||
|
|
||||||
|
- Modifica coefficienti di conversione in-app
|
||||||
|
- Calcolo kcal
|
||||||
|
- Generazione automatica lista spesa dai pasti pianificati
|
||||||
|
- Sync cloud
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Checklist
|
||||||
|
|
||||||
|
- [ ] Meal planner funzionante
|
||||||
|
- [ ] Conversioni corrette
|
||||||
|
- [ ] JSON alimenti presente (12+ voci)
|
||||||
|
- [ ] Lista spesa funzionante
|
||||||
|
- [ ] Persistenza attiva
|
||||||
|
- [ ] APK testabile
|
||||||
Reference in New Issue
Block a user