When you browse a hierarchy in a business view, you can click the caret icon >, which expands the hierarchy node. The default behavior is to show a caret icon even if there are no child records to browse under a node.
For example, a caret icon is displayed for every customer in this hierarchy view.
data:image/s3,"s3://crabby-images/fe89a/fe89a78992cfe289b6db780c36176a9ce036006f" alt=""
This behavior is undesirable. When I expand ABC Supply Co, Addison Lee, and AG2R La Mondiale, there are no children beneath these nodes.
data:image/s3,"s3://crabby-images/f66b7/f66b72925c0e90d019dd2277b94d38987e1abb27" alt=""
It would be best to only show the caret icon if there are child records to browse.
You can control this behavior using a SemQL filter on the Transition in the Entity Objects under the Business View.
How to add the filter on the transition
- Open the Business View in the Application Builder.
- In the Transitions, find the transition that controls the hierarchy nodes you want to see. In my example, that is Subsidiaries.
- Go to Hierarchy Configurations in the Properties.
- Enable SemQL for the Enable in Hierarchy option, instead of using the checkbox.
- Add the following SemQL expression. You will need to modify it to use your child reference.
ANY Subsidiaries HAVE ( ID IS NOT NULL )
data:image/s3,"s3://crabby-images/75bc1/75bc106cfae967d12c3787cccf98e918f4ef6993" alt=""
data:image/s3,"s3://crabby-images/d1317/d1317acb7e5b5ed5544c775fbc8c74a1621f5da7" alt=""
After you refresh the application, you should see the new improvement. Only companies with child records will show the caret icon.
data:image/s3,"s3://crabby-images/8df03/8df03b448164830f5eb5f482a7c3e436047a8683" alt=""