Cette macro est le pendant de la macro groupHeader. En plaçant cette macro dans le contenu de la macro groupList, il est possible, lors du parcours de la séquence ordonnée, de détecter lorsque l'élément courant est le dernier élément d'un groupe afin d'exécuter le contenu imbriqué de cette macro.
Cette macro peut être utilisée pour afficher des informations sur le groupe courant (un sous-total par exemple) après avoir affiché le contenu de l'élément courant.
Lors du parcours de la séquence ordonnée, le contenu imbriqué de cette macro ne s'exécutera qu'une fois par groupe : lorsque l'élément courant est le dernier du groupe.
Par exemple
<#assign seqData = [{"name": "mary", "age": 18}, {"name": "Lucy", "age": 19}, {"name": "Mark", "age": 19}, {"name": "Charlie", "age": 17}, {"name": "Aaron", "age": 18}, {"name": "Tess", "age": 16}, {"name": "Isaac", "age": 16} ]/> <#assign orderingCriteria = {"name": "original_order_by_age", "colName": "age", "order":"o"} /> <@hardisAdv.groupList .data_model.seqData orderingCriteria; aPerson> ${ aPerson.name} has ${ aPerson.age } <@hardisAdv.groupFooter "original_order_by_age"> End of age group. </@hardisAdv.groupFooter> </@hardisAdv.groupList>
a pour résultat :
Mary has 18
End of age group.
Lucy has 19
Mark has 19
End of age group.
Charlie has 17
End of age group.
Aaron has 18
End of age group.
Tess has 16
Isaac has 16
End of age group.
De plus, il est possible d'accéder aux informations du groupe de l'élément courant, en passant à la macro une variable de boucle qui sera alimentée par celle-ci et pourra être utilisée dans son contenu imbriqué. Cette variable est un objet Hash qui regroupe les informations sur le groupe via les attributs suivants :
- label : titre du groupe,
- startRow : numéro de ligne dans la séquence ordonnée du premier élément du groupe,
- endRow : numéro de ligne dans la séquence ordonnée du dernier élément du groupe,
- namedGroup : nom du groupe nommé si le groupe de l'élément courant est un groupe nommé.
Par exemple
<#assign seqData = [{"name": "mary", "age": 18}, {"name": "Lucy", "age": 19}, {"name": "Mark", "age": 19}, {"name": "Charlie", "age": 17}, {"name": "Aaron", "age": 18}, {"name": "Tess", "age": 16}, {"name": "Isaac", "age": 16} ]/> <#assign orderingCriteria = {"name": "original_order_by_age", "colName": "age", "order":"o"} /> <@hardisAdv.groupList .data_model.seqData orderingCriteria; aPerson> ${ aPerson.name} has ${ aPerson.age } <@hardisAdv.groupFooter "original_order_by_age"; infoGroupOriginalOrderByAge> End of group of ${ infoGroupOriginalOrderByAge .label}: ${ infoGroupOriginalOrderByAge .endRow - infoGroupOriginalOrderByAge .startRow } people </@hardisAdv.groupFooter> </@hardisAdv.groupList>
a pour résultat :
Mary has 18
End of group of 18: 1 people
Lucy has 19
Mark has 19
End of group of 19: 2 people
Charlie has 17
End of group of 17: 1 people
Aaron has 18
End of group of 18: 1 people
Tess has 16
Isaac has 16
End of group of 16: 2 people
Directive vide : Non
Paramètres
String |
groupName |
Nom du groupe dont on veut détecter la sortie lors du parcours |
Obligatoire |
Par exemple
<@hardisAdv.groupList .data_model.seqItems orderingCriteria; aItem> <@hardisAdv.groupHeader "orderGroup1"; infoGroup> Beginning of group ${ infoGroup.label } </@hardisAdv.groupHeader> … ${ aItem.fooAttribute} … <@hardisAdv.groupFooter "orderGroup1"; infoGroup> End of group ${ infoGroup.label } </@hardisAdv.groupFooter> </@hardisAdv.groupList>