Gegeben
sei ein InfoPath Formular zur Erfassung einer Bestellung. Das Formular wurde in
einer Formularbibliothek im SharePoint veröffentlicht und enthält eine
wiederholte Tabelle. Die Felder eines InfoPath Formulars lassen sich mit Hilfe
der Property Promotion als Spalten in SharePoint anzeigen. Bei Feldern in einer
wiederholten Tabelle (wiederholtes Feld) ist dies zwar möglich, allerdings
stehen in der SharePoint Spalte nur die Daten der ersten Zeile der Tabelle. Mit
Nintex Workflow ist es möglich, auf einzelne Zeilen einer wiederholten Tabelle
zuzugreifen, um zum Beispiel aus den einzelnen Positionen in einer zweiten
Liste neue Elemente anzulegen.
Beim
Absenden des Formulars wird eine XML-Datei in der Formularbibliothek
gespeichert. Diese XML-Datei kann im Nintex Workflow ausgelesen werden.
Zum
Auslesen der XML-Datei wird die Aktion „Query XML" verwendet. In der
Konfiguration der Aktion kann mittels XPath auf die Formularfelder zugegriffen
und in einer Collection Variable gespeichert werden. Wir speichern die
Artikelbezeichnung in der Variable „collArtikel" und die Menge in der
Variable „collMenge".
In der For Each Aktion wird eine der beiden Collection Variablen angegeben und eine Output Variable festgelegt.
Wichtig an dieser Stelle ist eine Variable
für den Index. Diese wird benötigt, um in einem weiteren Collection Vorgang den
richtigen Datensatz für die Menge auszulesen.
Innerhalb der For Each Schleife muss für
jedes Feld aus der wiederholten Tabelle ein Collection Vorgang platziert
werden. Aus der Variable collMenge wird das Element mit dem Index
„numIndex" (aktuelles Element der For Each Schleife) ausgelesen und der Wert in der Variable „Menge" gespeichert.
Nach den Collection Vorgängen zum Auslesen
des Datensatzes, kann innerhalb der For Each Schleife eine Create List Item
Aktion hinzugefügt werden, um für jede Position der Bestellung in einer
separaten Liste ein neues Listenelement anzulegen.