2026-01-28 13:31:42 +01:00
|
|
|
# Segnapunti Anto
|
2023-06-01 15:25:21 +02:00
|
|
|
|
2026-01-28 13:31:42 +01:00
|
|
|
Applicazione web **Progressive Web App (PWA)** per tracciare i punteggi di partite di pallavolo in tempo reale.
|
2023-06-01 15:25:21 +02:00
|
|
|
|
2026-01-28 13:31:42 +01:00
|
|
|
---
|
|
|
|
|
|
|
|
|
|
## Panoramica
|
|
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
**Segnapunti Anto** e un'applicazione digitale per il tracciamento del punteggio durante partite di pallavolo, ottimizzata per tablet e smartphone.
|
|
|
|
|
|
|
|
|
|
L'app e composta da due interfacce:
|
|
|
|
|
- **Display** (tabellone pubblico)
|
|
|
|
|
- **Controller** (pannello operatore)
|
|
|
|
|
|
|
|
|
|
Le due interfacce condividono lo stato in tempo reale tramite WebSocket.
|
|
|
|
|
|
|
|
|
|
### Funzionalita Principali
|
|
|
|
|
|
|
|
|
|
- **Gestione partita in tempo reale**
|
|
|
|
|
- Tracciamento punti home/guest
|
|
|
|
|
- Gestione set
|
|
|
|
|
- Indicatore servizio
|
|
|
|
|
- Storico punti (striscia)
|
|
|
|
|
- Blocchi logici quando il set e gia vinto
|
|
|
|
|
|
|
|
|
|
- **Regole pallavolo integrate**
|
|
|
|
|
- Set normali: vittoria a 25 con almeno 2 punti di scarto
|
|
|
|
|
- Set decisivo: vittoria a 15 con almeno 2 punti di scarto
|
|
|
|
|
- Modalita partita `2/3` o `3/5`
|
|
|
|
|
|
|
|
|
|
- **Formazioni e cambi**
|
|
|
|
|
- Gestione formazione a 6 giocatori
|
|
|
|
|
- Rotazione automatica al cambio palla
|
|
|
|
|
- Dialog cambi con validazioni (`IN -> OUT`)
|
|
|
|
|
|
|
|
|
|
- **Controlli e personalizzazione**
|
|
|
|
|
- Configurazione nomi squadre
|
|
|
|
|
- Toggle ordine squadre (inverti)
|
|
|
|
|
- Toggle visualizzazione punteggio/formazioni
|
|
|
|
|
- Toggle striscia storico
|
|
|
|
|
- Sintesi vocale punteggio (Web Speech API)
|
2026-01-28 13:31:42 +01:00
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
## Requisiti
|
|
|
|
|
|
|
|
|
|
### Requisiti di Sistema
|
|
|
|
|
|
|
|
|
|
#### Per Sviluppo
|
2026-02-12 19:44:17 +01:00
|
|
|
- **Sistema Operativo**: Linux, macOS, Windows
|
|
|
|
|
- **Node.js**: `>= 18.19.0` (consigliato `20 LTS`)
|
|
|
|
|
- **npm**: `>= 9`
|
|
|
|
|
- **RAM**: minimo 2GB (consigliato 4GB)
|
|
|
|
|
|
|
|
|
|
#### Per Esecuzione Test E2E
|
|
|
|
|
- Browser Playwright installati (`chromium`, `firefox`)
|
|
|
|
|
- Su Linux, eventuali dipendenze sistema per browser headless
|
2026-01-28 13:31:42 +01:00
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
Comandi utili:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
node -v
|
|
|
|
|
npm -v
|
|
|
|
|
npx playwright install chromium firefox
|
|
|
|
|
# Linux, se necessario:
|
|
|
|
|
# npx playwright install --with-deps chromium firefox
|
|
|
|
|
```
|
2026-01-28 13:31:42 +01:00
|
|
|
|
|
|
|
|
### Requisiti Browser (Utente Finale)
|
|
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
| Requisito | Dettaglio | Necessita |
|
2026-01-28 13:31:42 +01:00
|
|
|
|-----------|-----------|-----------|
|
2026-02-12 19:44:17 +01:00
|
|
|
| JavaScript ES6+ | Moduli, async/await | Obbligatorio |
|
|
|
|
|
| WebSocket | Sincronizzazione stato live | Obbligatorio |
|
|
|
|
|
| Service Worker API | Supporto PWA offline | Consigliato |
|
|
|
|
|
| Web Speech API | Annunci vocali | Opzionale |
|
2026-01-28 13:31:42 +01:00
|
|
|
|
|
|
|
|
### Browser Testati e Supportati
|
|
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
| Browser | Supporto | Note |
|
|
|
|
|
|---------|----------|------|
|
|
|
|
|
| Chrome/Chromium | ✅ | Completo |
|
|
|
|
|
| Firefox | ✅ | Completo |
|
|
|
|
|
| Mobile Chrome (Playwright Pixel 5) | ✅ | Copertura E2E mobile |
|
2026-01-28 13:31:42 +01:00
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
## Installazione e Setup
|
|
|
|
|
|
|
|
|
|
### Prerequisiti
|
|
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
- Node.js `>= 18.19.0`
|
|
|
|
|
- npm `>= 9`
|
2026-01-28 13:31:42 +01:00
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
### Installazione
|
2026-01-28 13:31:42 +01:00
|
|
|
|
|
|
|
|
```bash
|
2026-02-12 19:44:17 +01:00
|
|
|
git clone https://santantonio.sytes.net/attilio/segnapunti.git
|
2026-01-28 13:31:42 +01:00
|
|
|
cd segnapunti
|
|
|
|
|
npm install
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
## Comandi per Sviluppo
|
|
|
|
|
|
|
|
|
|
### Dev Server
|
|
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
Avvia il server di sviluppo Vite:
|
2026-01-28 13:31:42 +01:00
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
npm run dev
|
|
|
|
|
```
|
|
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
Accesso tipico in sviluppo:
|
|
|
|
|
- `http://localhost:5173/` -> Display
|
|
|
|
|
- `http://localhost:5173/controller.html` -> Controller
|
2026-01-28 13:31:42 +01:00
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
### Modalita Sviluppo
|
|
|
|
|
- Hot reload attivo
|
|
|
|
|
- Build veloce lato Vite
|
|
|
|
|
- Buona per sviluppo UI/UX
|
2026-01-28 13:31:42 +01:00
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
## Comandi per Build
|
|
|
|
|
|
|
|
|
|
### Build Produzione
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
npm run build
|
|
|
|
|
```
|
|
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
Output:
|
|
|
|
|
- cartella `dist/`
|
|
|
|
|
- asset ottimizzati
|
|
|
|
|
- file PWA (manifest + service worker)
|
2026-01-28 13:31:42 +01:00
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
### Avvio Server Applicativo Locale (Display + Controller)
|
2026-01-28 13:31:42 +01:00
|
|
|
|
|
|
|
|
```bash
|
2026-02-12 19:44:17 +01:00
|
|
|
npm run serve
|
2026-01-28 13:31:42 +01:00
|
|
|
```
|
|
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
Espone:
|
|
|
|
|
- `http://localhost:3000` -> Display
|
|
|
|
|
- `http://localhost:3001` -> Controller
|
2026-01-28 13:31:42 +01:00
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
### Altri comandi utili
|
2026-01-28 13:31:42 +01:00
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
```bash
|
|
|
|
|
npm run preview
|
|
|
|
|
npm run start
|
|
|
|
|
```
|
2026-01-28 13:31:42 +01:00
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
## Configurazione PWA
|
|
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
L'app usa `vite-plugin-pwa` (vedi `vite.config.js`) con:
|
|
|
|
|
- `registerType: 'autoUpdate'`
|
|
|
|
|
- manifest installabile
|
|
|
|
|
- orientamento landscape
|
|
|
|
|
- modalita fullscreen
|
2026-01-28 13:31:42 +01:00
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
Caratteristiche principali:
|
|
|
|
|
- installabile su dispositivi supportati
|
|
|
|
|
- aggiornamento automatico del service worker
|
|
|
|
|
- supporto utilizzo offline (in base alle risorse cache)
|
2026-01-28 13:31:42 +01:00
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
## Logica Regolamentare Pallavolo
|
|
|
|
|
|
|
|
|
|
### Vittoria Set
|
|
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
- Set normali: vittoria a 25 con almeno 2 punti di scarto
|
|
|
|
|
- Set decisivo: vittoria a 15 con almeno 2 punti di scarto
|
|
|
|
|
- Modalita partita supportate: `2/3` e `3/5`
|
2026-01-28 13:31:42 +01:00
|
|
|
|
|
|
|
|
### Rotazione Formazione
|
|
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
La rotazione avviene durante i cambi palla secondo la logica implementata in `src/gameState.js`.
|
2026-01-28 13:31:42 +01:00
|
|
|
|
|
|
|
|
### Formazione in Campo
|
|
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
Il sistema gestisce 6 posizioni per squadra e permette cambi validati da Controller.
|
2026-01-28 13:31:42 +01:00
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
---
|
|
|
|
|
|
|
|
|
|
## Test (stato attuale)
|
|
|
|
|
|
|
|
|
|
Suite presenti:
|
|
|
|
|
- Unit
|
|
|
|
|
- Integration
|
|
|
|
|
- Component
|
|
|
|
|
- Stress
|
|
|
|
|
- E2E (Playwright)
|
|
|
|
|
|
|
|
|
|
Comandi principali:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
npm run test:all
|
|
|
|
|
npm run test:e2e
|
2026-01-28 13:31:42 +01:00
|
|
|
```
|
|
|
|
|
|
2026-02-12 19:44:17 +01:00
|
|
|
Guida completa test:
|
|
|
|
|
- `tests/README.md`
|