I’m trying to create a JSON array using the Text Aggregator to group messages retrieved from a Data Store > Search Records module. Here’s my situation:
Context:
The Data Store returns multiple bundles with Role and Message fields, which are visible in the Debug Panel.
By default, Text Aggregator always returns data in text format.
Instead of Text Aggregator use the Parse JSON module.
Also used to store that array on some of the keys, which is a best practice and makes it easy to use on the next module.
Add these into your Parse JSON module. Change the content value accordingly.
Example:
Instead of Text Aggregator, use an Array Aggregator.
Aggregators
Every result (item/record) from iterator/list/search/match modules will output a bundle. This can result in multiple bundles, which then trigger multiple operations in future modules (one operation per bundle). To “combine” multiple bundles into a single variable, you’ll need to use an aggregator of some sort.
Aggregators are modules that accumulate multiple bundles into one single bundle. An example of a commonly-used aggregator module is the Array aggregator module. The next popular aggregator is the Text Aggregator which is very flexible and can apply to many use-cases like building of JSON, CSV, HTML.
Read this:
Array Aggregator – mapping multiple bundles into a complex field
The Array Aggregator module is very powerful because it allows you to build a complex array of collections for a later module’s field to map multiple items (collections) to it.
This is done using the “Target structure type” of an Array Aggregator module.
As you can see, the “Map” toggle on complex fields are used when you have an array. You can easily build an array variable to map to a future module’s field, by using an Array Aggregator module and select the “Target Structure Type” as the future module’s field you have mapped the array into.
Hope this helps! Let me know if there are any further questions or issues.