Tabelle in moduli adattivi tables-in-adaptive-forms
L’Adobe consiglia di utilizzare l’acquisizione dati moderna ed estensibile Componenti coreper creazione di un nuovo Forms adattivoo aggiunta di Forms adattivo alle pagine AEM Sites. Questi componenti rappresentano un progresso significativo nella creazione di Forms adattivi, garantendo esperienze utente straordinarie. Questo articolo descrive un approccio precedente all’authoring di Forms adattivi utilizzando i componenti di base.
L’utilizzo delle tabelle è un modo efficace, semplificato e organizzato di presentare dati complessi. Consente agli utenti di identificare facilmente le informazioni e di fornire input in una disposizione ordinata di righe e colonne. La maggior parte dei moduli di organizzazioni governative e di servizi finanziari richiede tabelle di dati di grandi dimensioni per inserire numeri ed eseguire calcoli.
AEM Forms fornisce un componente Tabella nella barra laterale del browser Componenti che consente di creare tabelle in moduli adattivi. Alcune delle funzionalità chiave fornite sono:
- Layout reattivo su dispositivi mobili
- Righe e colonne configurabili
- Aggiunta ed eliminazione dinamica di righe in fase di runtime
- 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
- Unire dati da un file XML
Creare una tabella create-a-table
Per creare una tabella, trascina 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 about-header-and-body-cells
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 dell'intestazione e scegliere Modifica. Nella finestra di dialogo Modifica, aggiorna l’etichetta nella sezione Valore e fai clic su OK.
Per impostazione predefinita, le celle del corpo sono caselle di testo. È possibile sostituire una cella del corpo con qualsiasi altro componente di moduli adattivi disponibile nella barra laterale, ad esempio una casella numerica, un selettore data o un elenco a discesa.
Ad esempio, la prima riga del corpo della tabella seguente include i componenti casella di testo, selezione data e elenco a discesa come celle.
È possibile unire due o più celle del corpo selezionando le celle da unire, facendo clic con il pulsante destro del mouse e selezionando Unisci. È inoltre possibile dividere una cella unita facendo clic con il pulsante destro del mouse e selezionando Dividi celle.
Aggiungere, eliminare e spostare righe e colonne add-delete-move-rows-and-columns
È possibile aggiungere ed eliminare una riga o una colonna e spostare una riga verso l'alto o il basso in una tabella.
Per aggiungere o eliminare una riga o una colonna o spostare una riga, fare clic su una cella della riga o della colonna. Nella parte superiore della colonna e a sinistra della riga viene visualizzato un menu a discesa. Il menu nella parte superiore fornisce le 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 della colonna selezionata.
- L'operazione Elimina elimina la riga o la colonna selezionata.
- Le operazioni Sposta su e Sposta giù spostano 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 delle righe.
Aggiungi descrizione tabella add-table-description
È possibile aggiungere una descrizione della tabella per spiegare come sono organizzate le informazioni che gli assistenti vocali possono interpretare e leggere. Per aggiungere la descrizione:
- Seleziona la tabella e seleziona. per visualizzarne le proprietà nella barra laterale.
- Specificare il riepilogo nella scheda Accessibilità.
- Clic Fine.
Ordinare le colonne in una tabella sortcolumnstable
Puoi 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 della tabella contenenti:
- Testo statico
- Proprietà oggetto modello dati
- Combinazione di testo statico e proprietà dell’oggetto modello dati
Per applicare l'ordinamento alle colonne della tabella, le celle delle colonne della tabella devono contenere uno dei seguenti componenti: Casella numerica, Stepper numerico, Campo immissione data, Selettore data, Testo o Casella di testo.
Per abilitare l'ordinamento:
-
Seleziona la tabella e seleziona. (Configura). È inoltre possibile selezionare la tabella utilizzando Contenuto nella barra laterale della comunicazione interattiva.
-
Seleziona Abilita ordinamento.
-
Seleziona per salvare le proprietà della tabella. Le icone di ordinamento, frecce verso l’alto o il basso, nelle intestazioni di colonna indicano che l’ordinamento è stato abilitato.
-
Passa a Anteprima per visualizzare l'output. La tabella viene ordinata automaticamente in base alla prima colonna della tabella.
-
Fai 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 nella colonna vengono visualizzati in ordine crescente.
Analogamente, un'intestazione di colonna con una freccia in giù indica che i valori nella colonna vengono visualizzati in ordine decrescente.
Puoi anche apportare modifiche alla tabella in Anteprima e fare di nuovo clic sull'intestazione di colonna per ordinare i valori di colonna.
Impostare la larghezza delle colonne per una tabella set-column-width
Per impostare la larghezza delle colonne per una tabella, eseguire la procedura seguente:
-
In Contenuto , seleziona la scheda Tabella e selezionare Configura ( icona ).
-
Inserisci l’elenco di valori separati da virgole nel Larghezza colonna per specificare la larghezza proporzionale di ciascuna colonna della tabella. Ad esempio, per una tabella che include 3 colonne, specificando 2,4,6 come valore nella Larghezza colonna In questo campo la larghezza delle colonne viene impostata su 2/12 per la prima colonna, 4/12 per la seconda colonna e 6/12 per la terza colonna. 2/12, in quanto la larghezza della prima colonna si riferisce a un sesto della larghezza della tabella. Analogamente, 4/12 imposta la larghezza della seconda colonna come un terzo della larghezza della tabella e 6/12 imposta la larghezza della terza colonna come metà della larghezza della tabella.
Configura stile tabella configure
È possibile definire lo stile di una tabella utilizzando la modalità Stile nella barra degli strumenti della pagina. Per passare alla modalità stile e modificare lo stile della tabella, effettuare le seguenti operazioni
-
Nella barra degli strumenti della pagina, prima di Anteprima, seleziona > Stile.
-
Nella barra laterale seleziona la tabella e fai clic sul pulsante Modifica .
Le proprietà di stile sono visibili nella barra laterale.
Aggiungere o eliminare una riga in modo dinamico add-or-delete-a-row-dynamically
Le tabelle forniscono supporto preconfigurato per l’aggiunta o l’eliminazione dinamica di righe in fase di esecuzione.
- Seleziona una riga di tabella e seleziona .
- Nella scheda Impostazioni ripetizione, specifica i conteggi minimo e massimo per limitare il numero di righe nella tabella.
- Clic Fine.
In fase di runtime, verrà visualizzato + e - per aggiungere o eliminare una riga.
Espressioni in una tabella expressions-in-a-table
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 visualizzare il totale in una cella, abilitare o disabilitare una cella, convalidare l’input dell’utente e così via. Queste espressioni utilizzano API di modelli di script per moduli adattivi.
Mentre le tabelle e le righe supportano solo le espressioni di visibilità per controllarne la visibilità in base al valore restituito da un'espressione, le celle supportano le espressioni seguenti:
- Script di inizializzazione: per eseguire un'azione all'inizializzazione di un campo.
- Script per conferma valore: per modificare i componenti di un modulo dopo la modifica del valore di un campo.
- Calcolare le espressioni: per calcolare automaticamente il valore di un campo.
- Espressioni di convalida: per convalidare un campo.
- Accedere alle espressioni: per abilitare/disabilitare 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 Modifica componente corrispondente. Le espressioni per una cella possono essere definite nella scheda Script della finestra di dialogo Modifica componente.
Per l’elenco completo delle classi, degli eventi, degli oggetti e delle API pubbliche dei moduli adattivi, consulta Riferimento API della libreria JavaScript per i moduli adattivi.
Layout dispositivi mobili mobile-layouts
Le tabelle nei moduli adattivi forniscono ai dispositivi mobili di esperienza senza precedenti grazie ai loro layout fluidi e reattivi. AEM Forms offre due tipi di layout mobili per tabelle: Intestazioni a sinistra e Colonne comprimibili.
Puoi configurare un layout mobile per una tabella dalla scheda Stile della finestra di dialogo Modifica componente per una tabella.
Intestazioni a sinistra headers-on-left
Nel layout Intestazioni a sinistra, l’intestazione della tabella viene trasposta a sinistra, con una sola cella visualizzata sopra 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 intestazione sul layout sinistro
Vista mobile di una tabella con intestazione sul layout a sinistra
Layout colonne comprimibile collapsible-columns-layout
Nel layout Colonne comprimibili, le colonne della tabella vengono compresse per mostrare una o due colonne, a seconda della dimensione del dispositivo, mentre le altre colonne vengono compresse. Puoi fare clic sull’icona di compressione/espansione per visualizzare altre colonne della 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 espansa di una tabella su un dispositivo mobile
Unire i dati in una tabella merge-data-in-a-table
Le tabelle nei moduli adattivi consentono di popolare la tabella in fase di esecuzione utilizzando i dati di un file XML. Il file XML dati può trovarsi nel file system locale del computer in cui è in esecuzione il server AEM Forms o nell’archivio CRX.
Prendiamo ad esempio la seguente tabella di riepilogo delle transazioni bancarie che si desidera compilare con i dati di un file XML.
In questo esempio, la proprietà Nome elemento per:
- la riga è Riga 1
- la cella del corpo sotto la data transazione è tableItem1
- la cella del corpo in Descrizione è tableItem2
- la cella body in Tipo di transazione è tipo
- la cella del 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>
Nel codice XML di esempio, i dati di una riga sono definiti dal <Row1>
tag: il nome dell’elemento per la riga della tabella. All'interno del <Row1>
, 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 puntare il modulo adattivo contenente la tabella alla posizione XML assoluta con wcmmode disabilitato. Ad esempio, se il modulo adattivo si trova https://localhost:4502/myForms/bankTransaction.html e il file XML 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 use-xdp-components-and-xsd-complex-types
Se hai creato un modulo adattivo basato su un modello di modulo XFA, gli elementi XFA sono disponibili nella scheda Modello dati di AEM Content Finder. Puoi trascinare e rilasciare questi elementi XFA, comprese le tabelle, nel modulo adattivo.
L’elemento della tabella XFA è mappato al componente Table e funziona come preconfigurato nei moduli adattivi. Tutte le proprietà e le funzionalità della tabella XDP vengono mantenute quando viene spostata in un modulo adattivo e puoi eseguirvi qualsiasi operazione proprio come con la tabella nativa del modulo adattivo. Ad esempio, se una riga in una tabella XDP è contrassegnata come ripetibile, verrà ripetuta quando viene rilasciata anche nei moduli adattivi.
Inoltre, puoi trascinare la sottomaschera XDP per aggiungere una nuova riga nella tabella. Si noti tuttavia che l'eliminazione di una sottomaschera nidificata non funziona.
Inoltre, puoi trascinare un gruppo di elementi di tipo complesso XSD per creare una riga di tabella. Viene creata una nuova riga appena sotto la riga in cui sono stati rilasciati gli elementi. Le celle create utilizzando gli elementi di tipo complesso XSD mantengono un riferimento di associazione a XSD. È inoltre possibile sostituire una cella body con un elemento di tipo complesso XSD rilasciando l'elemento sulla cella.
Considerazioni chiave key-considerations
-
Se si spostano le righe verso l'alto o verso il basso durante la creazione di una tabella basata su XSD, nell'XML dati generato all'invio del modulo viene visualizzata una perdita di dati dalle righe della tabella.
-
A ogni cella body di una tabella predefinita è associato un nome elemento predefinito. Se aggiungi un’altra tabella nel modulo adattivo, le celle del corpo predefinite nella nuova tabella avranno lo stesso nome elemento della prima tabella. In questo caso, i dati generati durante l'invio del modulo includeranno i dati nelle celle predefinite del corpo di una sola tabella. Assicurati pertanto di rinominare i nomi degli elementi per le celle del corpo predefinite per mantenerli univoci nelle tabelle ed evitare la perdita di dati.
Si noti che questo è applicabile solo alle celle del corpo di default. Se si aggiungono più righe o colonne a una tabella, verranno generati automaticamente nomi di elementi univoci per le celle del corpo non predefinite.