@underJSONObjectProperty makes the nested directive receive an entry from the queried JSON object.
This directive is particularly useful to extract and manipulate a desired piece of data after querying an external API, which will quite likely have a generic JSONObject type (as when using function field _sendJSONObjectItemHTTPRequest from the HTTP Client extension).
In the query below, we obtain a JSON object coming from the WP REST API, and we use @underJSONObjectProperty to manipulate the response's type property, transforming it to upper case:
This will produce:
In addition to receiving a "key" to point to a property that lives on the first level of the JSON object, this directive can also receive a "path" to navigate within the inner structure of the object, using . as a separator across levels.
In the query below, the WP REST API endpoint for a post provides property "title.rendered". We can navigate to that actual subelement, and transform it to title case:
@underEachArrayItem iterates over the array items from some field in the queried entity, and executes the nested directive(s) on each of them.
For instance, field Post.categoryNames is of type [String]. Using @underEachArrayItem, we can iterate the category names and apply the @strTranslate directive to them.
In this query, the post categories are translated from English to French:
...producing:
@underEachArrayItem can pass both the index and the value of the iterated-upon element as a dynamic variable to its nested directive(s), via directive args passIndexOnwardsAs and passValueOnwardsAs.
This query demonstrates the use of dynamic variables $index and $value:
The result is:
@underEachArrayItem can also limit the positions of the array to iterate upon, via param filter->by, which can accept either entry include or exclude.
@underEachJSONObjectProperty is similar to @underEachArrayItem, but operating on JSONObject elements.
In this query, we iterate all entries in the JSON object and replace any null entry with an empty string:
...producing:
@underEachJSONObjectProperty can pass the key and the value it is iterating on as a dynamic variable to its nested directive(s), via directive args passKeyOnwardsAs and passValueOnwardsAs.
This query demonstrates the use of dynamic variables $key and $value:
The result is:
@underEachJSONObjectProperty can also limit the keys from the JSON object to iterate upon, via param filter->by, which can accept either entry includeKeys or excludeKeys.
JSON objects may be accessed by reference in the field resolvers (and not by copying/duplicating the object). When that is the case, when the JSON object is modified, this modification will be visible to all the fields that retrieve this JSON object.
This is the case with field Block.attributes:
...which produces:
In the query below, while originalAttributes is simply retrieving the attributes, transformedAttributes will also translate the content property to French:
However, as the queried Block entity references the same JSON object on both originalAttributes and transformedAttributes, the transformations performed by the latter field will also affect the former field (this is irrespective of the order in which they appear in the query).
As a result, both fields are translated to French:
We can avoid this issue by adding directive @objectClone on the transformedAttributes field, so that the modifications are performed on a cloned JSON object:
In this query, @underEachArrayItem wraps @underJSONObjectProperty, which itself wraps @strUpperCase, transforming the "title.rendered" property into upper case, for the multiple post entries obtained via the WP REST API: