Ciao a tutti,
devo realizzare un form con circa 200 campi su diverse pagine (l'utente devo poter andare avanti e indietro senza perdere i dati inseriti), alcuni campi sono a risposta multipla, altri a risposta singola e i dati vengono presi da diverse tabelle del DB (nel caso di option e checkbox), altri sono a testo libero, altri sono risposte si/no, in altri campi devo poter inserire N record (esempio: utenti partecipanti).
Alcuni campi sono vincolanti con altri e tra questi campi bisogna fare l'upload di diversi file.
L'utente deve poter salvare lo stato in qualsiasi momento per poter continuare in un altro momento anche da un altro computer (per quanto riguarda questo punto ci sar� un codice univoco che identificher� il form).
Stavo pensando di effettuare un unico form con le 200 domande, le differenti pagine saranno dei DIV e in base alla pagina in cui mi trovo nascondere i restanti DIV.
Ci saranno 3 bottoni 'avanti', 'indietro', 'registra e esci'.
Stavo pensando con AJAX, di generare una chiamata ogni volta che viene premuto uno di questi tre bottoni con tutti i dati del form e la pagina in cui si trova l'utente, verificare i dati lato javascript, chiamata Ajax, verificare i dati lato php, convertirlo in json e salvarlo in una tabella, associandolo al codice univoco che mi identifica il form.
In alto ci saranno poi dei bottoni che mi identificano il numero delle pagine, e potranno avere 3 stati:
verde, ok
rosso, pagina con errori
bianco, pagina non iniziata
Se l'utente ritorna sul form in un secondo momento, caricare i dati del formulario dalla tabella, popolare i campi del form e far continuare l'utente.
Per quanto riguarda la gestione dei file (caricati dall'utente), verranno inviati immediatamente con una chiamata ajax, non appena l'utente li sceglie. Nel json salver� solo il nome del file nella directory temporale che utilizzer� per fare l'upload dei file.
Una volta completato il form, scriver� i dati nelle rispettive tabelle del DB.
Cosa ne pensate?
Qualsiasi suggerimento e ben accetto!
Grazie,
Roberto