Show Menu
ARGOMENTI×

Tabelle nei moduli adattivi

L'utilizzo delle tabelle rappresenta un modo efficace, semplificato e organizzato di presentare dati complessi. Consente agli utenti di identificare facilmente le informazioni e fornire gli input in una disposizione ordinata di righe e colonne. La maggior parte dei moduli provenienti da servizi finanziari e organizzazioni governative richiede tabelle di dati di grandi dimensioni per inserire numeri ed eseguire calcoli.
In AEM Forms è disponibile un componente Tabella nel browser Componenti nella barra laterale che consente di creare tabelle nei moduli adattivi. Alcune delle funzionalità chiave che fornisce sono:
  • Layout reattivo su dispositivi mobili
  • Righe e colonne configurabili
  • Aggiunta ed eliminazione dinamica delle righe in fase di esecuzione
  • Combinare o unire e dividere le celle
  • Accessibile dagli assistenti vocali
  • Layout personalizzato con CSS
  • Compatibile e mappato con il componente tabella XDP
  • Supporto per l'aggiunta di righe o celle utilizzando elementi di tipo complesso XSD
  • Unione di dati da un file XML

Creare una tabella

Per creare una tabella, trascinate il componente Tabella dal browser Componenti nella barra laterale del modulo adattivo. Per impostazione predefinita, la tabella contiene due colonne e tre righe, inclusa la riga di intestazione.

Informazioni sulle celle di intestazione e corpo

Le celle di intestazione sono campi di testo. Per modificare l’etichetta di un’intestazione, fare clic con il pulsante destro del mouse sulla cella di intestazione e scegliere Modifica . Nella finestra di dialogo Modifica, aggiornate l’etichetta nel campo Valore e fate clic su OK .
Per impostazione predefinita, le celle corpo sono caselle di testo. È possibile sostituire una cella corpo con qualsiasi altro componente di modulo adattivo disponibile nella barra laterale, ad esempio una casella numerica, un selettore data o un elenco a discesa.
Ad esempio, la prima riga corpo nella tabella seguente include come celle i componenti casella di testo, selezione data e elenco a discesa.
Per unire due o più celle corpo, selezionare le celle da unire, fare clic con il pulsante destro del mouse e selezionare Unisci . È inoltre possibile dividere una cella unita facendo clic con il pulsante destro del mouse e selezionando Dividi celle .

Aggiungere, eliminare, spostare righe e colonne

È possibile aggiungere ed eliminare una riga o una colonna e spostare una riga verso l'alto o il basso all'interno di una tabella.
Per aggiungere o eliminare una riga o una colonna o spostare una riga, fare clic su una cella della riga o colonna. Nella parte superiore della colonna e a sinistra della riga viene visualizzato un menu a discesa. Il menu in alto contiene opzioni per aggiungere o eliminare la colonna, mentre il menu a sinistra consente di aggiungere, eliminare o spostare la riga.
  • L'operazione Aggiungi aggiunge una riga sotto o una colonna a destra della riga o colonna selezionata.
  • L'operazione Elimina elimina la riga o la colonna selezionata.
  • L'operazione Sposta su e Sposta giù sposta la riga selezionata verso l'alto e verso il basso.
Il menu a discesa della riga fornisce inoltre l'operazione Modifica per modificare le proprietà, le impostazioni e le opzioni di stile della riga.
Anche se è possibile aggiungere un numero qualsiasi di righe in una tabella, il numero massimo di colonne è sei. Inoltre, non è possibile eliminare la riga di intestazione dalla tabella.

Aggiungi descrizione tabella

È possibile aggiungere una descrizione della tabella per spiegare in che modo le informazioni sono organizzate che gli assistenti vocali possono interpretare e leggere. Per aggiungere la descrizione:
  1. Selezionate la tabella e toccate per visualizzarne le proprietà nella barra laterale.
  2. Specificare un riepilogo nella scheda Accessibilità.
  3. Fate clic su Fine .

Ordinare le colonne in una tabella

È possibile ordinare i dati in base a qualsiasi colonna di una tabella nel modulo adattivo. I valori nella colonna possono essere ordinati in ordine crescente o decrescente.
L'ordinamento può essere applicato alle colonne di tabella contenenti:
  • Testo statico
  • Proprietà dell'oggetto modello dati
  • Combinazione di proprietà statiche dell'oggetto testo e modello dati
Per applicare l'ordinamento alle colonne di tabella, le celle delle colonne di tabella devono contenere i seguenti componenti: Casella numerica, Timbro numerico, Campo immissione data, Selettore data, Testo o Casella di testo.
Per abilitare l'ordinamento:
  1. Seleziona la tabella e tocca (Configura). Potete anche selezionare la tabella utilizzando il browser Contenuto nella barra laterale della comunicazione interattiva.
  2. Selezionate Abilita ordinamento .
  3. Toccate per salvare le proprietà della tabella. Le icone di ordinamento, le frecce su e giù, nelle intestazioni delle colonne, indicano che l'ordinamento è stato attivato.
  4. Passate alla modalità Anteprima per visualizzare l’output. La tabella viene ordinata automaticamente in base alla prima colonna della tabella.
  5. Fate clic sull’intestazione della colonna per ordinare i valori in base alla colonna.
    Un'intestazione di colonna con una freccia su indica che la tabella è ordinata in base a tale colonna. Inoltre, i valori della colonna vengono visualizzati in ordine crescente.
    Analogamente, un'intestazione di colonna con una freccia rivolta verso il basso rappresenta la visualizzazione dei valori della colonna in ordine decrescente.
    È inoltre possibile apportare modifiche alla tabella in modalità Anteprima e fare di nuovo clic sull’intestazione della colonna per ordinare i valori delle colonne.

Configura stile tabella

È possibile definire lo stile di una tabella utilizzando la modalità Stile nella barra degli strumenti della pagina. Per passare alla modalità di stile e modificare lo stile della tabella, procedere come segue.
  1. Nella barra degli strumenti della pagina, prima di Anteprima, toccate > Stile .
  2. Nella barra laterale selezionate la tabella e toccate il pulsante Modifica . Potete visualizzare le proprietà di stile nella barra laterale.
È possibile modificare il tema colore per le righe di intestazione e le righe corpo modificando i valori delle variabili LESS. Per ulteriori informazioni, consultate Temi in AEM Forms Creazione di temi modulo adattivi personalizzati .

Aggiunta o eliminazione dinamica di una riga

Le tabelle forniscono supporto out-of-the-box per l'aggiunta o l'eliminazione dinamica di righe in fase di esecuzione.
  1. Selezionare una riga di tabella e toccare .
  2. Nella scheda Impostazioni ripetizione, specificare i conteggi minimo e massimo per limitare il numero di righe nella tabella.
  3. Fate clic su Fine .
In fase di esecuzione, verranno visualizzati + e ** i pulsanti per aggiungere o eliminare una riga.
L'aggiunta o l'eliminazione dinamica di una riga non è supportata nelle intestazioni nel layout mobile sinistro delle tabelle.

Espressioni in una tabella

Le tabelle nei moduli adattivi consentono di scrivere espressioni in JavaScript per indurre comportamenti quali mostrare o nascondere una tabella o una riga, sommare tutti i numeri e mostrare il totale in una cella, attivare o disattivare una cella, convalidare l'input dell'utente e così via. Queste espressioni utilizzano le API del modello di script dei moduli adattivi.
Mentre tabelle e righe supportano solo le espressioni di visibilità per controllarne la visibilità in base al valore restituito da un'espressione, le celle supportano le seguenti espressioni:
  • Script di inizializzazione: per eseguire un'azione all'inizializzazione di un campo.
  • Script di conferma del valore: per modificare i componenti di un modulo dopo la modifica del valore di un campo.
Se lo script XFA change/exit è applicato anche allo stesso campo, lo script XFA change/exit viene eseguito prima dello script Value Commit.
  • Calcola espressioni : per calcolare automaticamente il valore di un campo.
  • Espressioni di convalida: per convalidare un campo.
  • Espressioni di accesso: per attivare/disattivare un campo.
  • Espressione di visibilità: per controllare la visibilità di un campo e di un pannello.
L’espressione di visibilità per una tabella o una riga può essere definita nella scheda Proprietà pannello della finestra di dialogo corrispondente del componente Modifica. Le espressioni per una cella possono essere definite nella scheda Script della finestra di dialogo del componente Modifica.
Per l'elenco completo delle classi, degli eventi, degli oggetti e delle API pubbliche dei moduli adattivi, consultare il documento Riferimento API della libreria JavaScript per i moduli adattivi.

Layout per dispositivi mobili

Le tabelle nei moduli adattivi offrono un'esperienza senza confronti per i dispositivi mobili grazie ai layout fluidi e reattivi. In AEM Forms sono disponibili due tipi di layout per dispositivi mobili per le tabelle: Intestazioni sulle colonne sinistra e Comprimibili.
È possibile configurare un layout mobile per una tabella dalla scheda Stile della finestra di dialogo del componente Modifica per una tabella.

Headers on left

Nel layout Intestazioni a sinistra, l’intestazione della tabella viene trasposta a sinistra, con una sola cella che appare su un’intestazione. Ogni riga in questo layout viene visualizzata come una sezione distinta. Le immagini seguenti confrontano una tabella su un desktop con quella su un dispositivo mobile.
Vista desktop di una tabella con il layout Intestazione a sinistra
Vista mobile di una tabella con il layout Intestazione a sinistra

Layout colonne comprimibili

Nel layout della colonna Comprimibile, le colonne della tabella vengono ridotte per mostrare una o due colonne, a seconda della dimensione del dispositivo, mentre le altre colonne vengono ridotte. È possibile fare clic sull'icona di compressione/espansione per visualizzare altre colonne nella tabella.
Anche se il layout di colonna Comprimibile è ottimizzato per i dispositivi mobili, funzionerà anche su desktop, se la larghezza disponibile non è sufficiente per mostrare tutte le colonne di una tabella.
Le immagini seguenti confrontano l'aspetto di una tabella su un dispositivo con colonne compresse ed espanse.
Colonne compresse di una tabella con solo due colonne visualizzate su un dispositivo mobile
Colonna estesa di una tabella su un dispositivo mobile

Unione di dati in una tabella

Le tabelle in moduli adattivi consentono di compilare la tabella in fase di esecuzione utilizzando i dati provenienti da un file XML. Il file XML di dati può risiedere nel file system locale del computer in cui è in esecuzione AEM Forms Server o nell'archivio CRX.
Esempio della tabella di riepilogo delle transazioni bancarie seguente che si desidera compilare con i dati provenienti da un file XML.
In questo esempio, la proprietà Nome elemento per:
  • la riga è Riga1
  • la cella corpo in Data transazione è tableItem1
  • la cella corpo in Descrizione è tableItem2
  • la cella corpo sotto il tipo di transazione è tipo
  • la cella corpo sotto Importo in USD è tableItem3
Il file XML che contiene i dati nel formato seguente:
<?xml version="1.0" encoding="UTF-8"?><afData>
  <afUnboundData>
    <data>
 <typeSelect>0</typeSelect>
 <Row1>
      <tableItem1>2015-01-08</tableItem1>
      <tableItem2>Purchase laptop</tableItem2>
      <type>0</type>
      <tableItem3>12000</tableItem3>
 </Row1>
 <Row1>
      <tableItem1>2015-01-05</tableItem1>
      <tableItem2>Transport expense</tableItem2>
      <type>0</type>
      <tableItem3>120</tableItem3>
 </Row1>
 <Row1>
      <tableItem1>2014-01-08</tableItem1>
      <tableItem2>Laser printer</tableItem2>
      <type>0</type>
      <tableItem3>500</tableItem3>
 </Row1>
 <Row1>
      <tableItem1>2014-12-08</tableItem1>
      <tableItem2>Credit card payment</tableItem2>
      <type>0</type>
      <tableItem3>300</tableItem3>
 </Row1>
 <Row1>
      <tableItem1>2015-01-06</tableItem1>
      <tableItem2>Interest earnings</tableItem2>
      <type>1</type>
      <tableItem3>12000</tableItem3>
 </Row1>
 <Row1>
      <tableItem1>2015-01-05</tableItem1>
      <tableItem2>Payment from a client</tableItem2>
      <type>1</type>
      <tableItem3>500</tableItem3>
 </Row1>
 <Row1>
      <tableItem1>2015-01-08</tableItem1>
      <tableItem2>Food expense</tableItem2>
      <type>0</type>
      <tableItem3>120</tableItem3>
 </Row1>
 </data>
  </afUnboundData>
  <afBoundData>
    <data/>
  </afBoundData>
  <afBoundData/>
</afData>

Nell'XML di esempio, i dati per una riga sono definiti dai <Row1> tag, che è il nome dell'elemento per la riga nella tabella. All'interno del <Row1> tag, i dati di ciascuna cella sono definiti all'interno del tag per il nome del relativo elemento, ad esempio <tableItem1> , <tableItem2> , <tableItem3> e <type> .
Per unire questi dati alla tabella in fase di esecuzione, è necessario indirizzare il modulo adattivo contenente la tabella nella posizione XML assoluta con wcmmode disattivato. Ad esempio, se il modulo adattivo si trova in https://localhost:4502/myForms/bankTransaction.html e il file XML di dati viene salvato in C:/myTransactions/bankSummary.xml , è possibile visualizzare la tabella con i dati al seguente URL:
https://localhost:4502/myForms/bankTransaction.html?dataRef=file:/// C:/myTransactions/bankSummary.xml&wcmmode=disabled

Utilizzare componenti XDP e tipi complessi XSD

Se avete creato un modulo adattivo basato su un modello di modulo XFA, gli elementi XFA sono disponibili nella scheda Modello dati di AEM Content Finder. È possibile trascinare questi elementi XFA, incluse le tabelle, nel modulo adattivo.
L’elemento tabella XFA è mappato sul componente Tabella e funziona out-of-the-box nei moduli adattivi. Tutte le proprietà e le funzionalità della tabella XDP vengono mantenute quando vengono spostate in un modulo adattivo e potete eseguire qualsiasi operazione su di esso, come avviene per la tabella di moduli adattivi nativi. Ad esempio, se una riga in una tabella XDP è contrassegnata come ripetibile, viene ripetuta anche se rilasciata in moduli adattivi.
È inoltre possibile trascinare il sottomodulo XDP per aggiungere una nuova riga nella tabella. Tuttavia, tenere presente che il rilascio di un sottomodulo nidificato non funziona.
Una tabella XDP senza riga di intestazione non verrà mappata al componente Tabella modulo adattivo. Verrà invece mappato sul componente Pannello modulo adattivo con layout fluido. Inoltre, quando si aggiunge una tabella nidificata da un XDP a un modulo adattivo, la tabella esterna viene convertita in un pannello mantenendo la tabella interna.
È inoltre possibile trascinare un gruppo di elementi di tipo complesso XSD per creare una riga di tabella. Viene creata una nuova riga immediatamente sotto la riga in cui sono stati eliminati gli elementi. Le celle create utilizzando gli elementi di tipo complesso XSD mantengono un riferimento di binding all'XSD. È inoltre possibile sostituire una cella corpo con un elemento di tipo complesso XSD rilasciando l'elemento sulla cella.
Il numero di elementi in un componente tabella XDP, un sottomodulo o un tipo complesso XSD non può superare il numero di celle in una riga. Ad esempio, non è possibile rilasciare quattro elementi su una riga con solo tre celle. Ne risulterà un errore.
Se il numero di elementi è inferiore al numero di celle in una riga, la nuova riga aggiunge prima le celle in base agli elementi, quindi le celle predefinite vengono aggiunte per riempire le celle rimanenti nella riga. Ad esempio, se rilasci un gruppo di tre elementi in una riga con quattro celle, le prime tre celle si basano sugli elementi rilasciati e la cella rimanente sarà quella predefinita.

Considerazioni chiave

  • Se si spostano le righe verso l'alto o il basso durante la creazione di una tabella basata su XSD, alcuni dati persi dalle righe della tabella vengono visualizzati nell'XML di dati generato all'invio del modulo.
  • A ogni cella corpo di una tabella predefinita è associato un nome di elemento predefinito. Se si aggiunge un'altra tabella nel modulo adattivo, le celle corpo predefinite della nuova tabella avranno lo stesso nome di elemento della prima tabella. In questo caso, i dati generati al momento dell'invio del modulo includeranno i dati nelle celle corpo predefinite di una sola tabella. Pertanto, è necessario rinominare i nomi degli elementi per le celle corpo predefinite in modo da mantenerle univoche tra le tabelle ed evitare la perdita di dati.
    Questo è applicabile solo alle celle corpo predefinite. Se si aggiungono più righe o colonne a una tabella, verranno generati automaticamente nomi di elementi univoci per le celle corpo non predefinite.