Con la funzionalità di “sottogriglia” si intende la possibilità, all'interno di una griglia, di espandere le righe della griglia stessa ed aggiungere a loro interno dell'html od un'ulteriore griglia.
Per attivare la possibilità di espandere le righe di una griglia, il seguente parametro va aggiunto ai metadati:
Chiave | Default | Valori |
---|---|---|
subgrid | false | true, false |
Per aggiungere una sottogriglia all'interno delle righe espanse è sufficiente aggiungere, all'interno della griglia, la sottogriglia che si vuole avere (allo stesso livello dei th ed i td), senza nessun specifico parametro.
Una griglia col parametro “subgrid” abilitato avrà la possibilità di generare due nuovi eventi: subGridRowExpanded e subGridRowCollapsed, scatenati rispettivamente all'espandere
ed al collassare di una riga.
Il primo porta con se anche un dato esclusivo, subgridDivId, spiegato nel prossimo paragrafo.
I seguenti parametri saranno disponibili nel $_POST delle chiamate effettuate in una griglia con paramtro “subgrid” e sottogriglie.
Parametro | Descrizione | Nota |
---|---|---|
subgridDivId | Indica l'ID dello spazio creato al di sotto della riga espansa. Utilizzato in coppia con Out::html per generare dell'HTML relativo alla riga espansa. | Solo con subGridRowExpanded |
subgridId | L'ID reale della griglia oggetto dell'evento, da utilizzare per il TableView e per tutte le funzioni che interagiscono direttamente con la griglia. | |
childId | L'ID generico (come da disegno) dell'eventuale sottogriglia presente nella riga oggetto dell'evento. Assente se la riga è collassata o non ci sono subgrid. | |
subgridChildId | L'ID reale dell'eventuale sottogriglia, come spiegato per childId. | |
subgridData | Un array contenente il percorso di griglie e rowid che puntano alla riga oggetto dell'evento. | Spiegato nel successivo paragrafo |
Per la gestione di array utilizzanti le subgrid sono state create delle funzioni, all'interno della classe TableView, per facilitare l'inserimento, il recupero e la cancellazione dei dati nei sotto-livelli.
A questo scopo itaEngine ci ritorna la variabile subgridData, che contiene tutte le informazioni di cui hanno bisogno le seguenti funzioni.
Aggiunge un sotto-livello in un dato array.
function TableView::addSubgridData($subgridInfo, $arrayData, $subgridId, $subgridData)
subgridInfo | $_POST['subgridData'] |
---|---|
arrayData | Array da elaborare. |
subgridId | ID della sotto-griglia che si sta aggiungendo. |
subgriData | Dati della sotto-griglia che si sta aggiungendo. |
Ritorna i dati della griglia finale in $subgridInfo, o della griglia specificata con il parametro $subgridId.
function TableView::getSubgridData($subgridInfo, $arrayData, $subgridId = false)
subgridInfo | $_POST['subgridData'] |
---|---|
arrayData | Array da elaborare. |
subgridId | (opzionale) ID della griglia di cui si vogliono i dati. |
Ritorna il record del rowid finale in $subgridInfo, o della griglia specificata con il parametro $subgridId (il rowid viene sempre preso in $subgridInfo).
function TableView::getSubgridRecord($subgridInfo, $arrayData, $subgridId = false)
subgridInfo | $_POST['subgridData'] |
---|---|
arrayData | Array da elaborare. |
subgridId | (opzionale) ID della griglia di cui si vuole il record. |
Cancella i dati della sotto-griglia indicata.
function TableView::deleteSubgridData($subgridInfo, $arrayData, $subgridId)
subgridInfo | $_POST['subgridData'] |
---|---|
arrayData | Array da elaborare. |
subgridId | ID della sotto-griglia che si vuole cancellare. |
5 visualizzazioni.