How to access repeating table/section fields in Info Path Web Browser Forms
Accessing or validating fields within a repeating table/section using web browser forms might be a little bit tricky, as web browser forms will not allow you to reference specific rows by index, use Last() or Position() functions...
There are some XPath formulas that you can use to access or validate fields within a repeating section with out having to use any extra code in your form.
These are some examples:
If value returned by the XPath expression is greater than 0 then the repeating table contains duplicate rows. The number returned by the XPath expression will be the number of duplicate rows that your repeating section contains.
Do not forget to include in the condition when field is not blank, as blank values count as duplicates.
This function is very useful as will allow you to compare the current row with the previous row or auto-fill the current row with the value of the previous row.
If you use it for validations, I recommend you to create a field within the repeating section that contains the previous row value and use this field to compare with the current row.
Note that the words in red refers to your own form structure and fields name.
There are some XPath formulas that you can use to access or validate fields within a repeating section with out having to use any extra code in your form.
These are some examples:
- Check if a repeating section/table has duplicate rows:
If value returned by the XPath expression is greater than 0 then the repeating table contains duplicate rows. The number returned by the XPath expression will be the number of duplicate rows that your repeating section contains.
Do not forget to include in the condition when field is not blank, as blank values count as duplicates.
- Get the previous row value:
This function is very useful as will allow you to compare the current row with the previous row or auto-fill the current row with the value of the previous row.
If you use it for validations, I recommend you to create a field within the repeating section that contains the previous row value and use this field to compare with the current row.
- Last() function, get the last row value:
- Position() function, get the current row index:
count(preceding-sibling::*[local-name() = "RepeatingGroup"])
Note that the words in red refers to your own form structure and fields name.
thanks for this tip! is there a way we can check if value of repeating column1 is greater than repeating column 2?
ReplyDeleteYes, you can access to the value of the previous row by using this function
ReplyDeletepreceding-sibling::my:MyRepeatingGroup[count(preceding-sibling::my:MyRepeatingGroup) = count(current()/preceding-sibling::my:MyRepeatingGroup) - 1]/my:FieldToAccess
Then you just need you compare the previous row with your current row
Whenever I try that formula, it tells me that the formula is invalid. my:MyRepeatingGroup shows up as ".." and that comes up as an error.
ReplyDelete