How Do I Refresh the Subform View Only on Modifying the Last Argument When Passing Several Arguments to the Subform? (Magic xpa 2.x)
Normally, the subform will refresh itself whenever any of the parameters that are being passed to it change. However, if there are several parameters -- such as search criteria for a list -- then the subform will refresh every time the user changes any one of the criteria. This might not be what the user expects, and it can also slow down processing if it’s a complex search.
-
On your parent task, make sure that your tab order is correct, by pressing on the Command palette.
-
Make sure the last field has a Control Name (“Studio”, in this example).
-
In the Subform control, set Automatic Refresh to No.
-
Make sure the subform has a control name (“DVD Titles” in this example).
-
In the Logic Editor, create a Control Suffix event for the last search criteria control.
-
Add a Raise Event operation that raises the internal event Subform Refresh.
-
As an argument to this event, pass the name of your subform (“DVD Titles” in this example).
Now, the subtask will refresh when the user passes the last control.
Hint: If this is combined with the Tab Into property on the subform, the user will enter the criteria and drop into the subform nicely. Also, in your Control Suffix control, you can add an Evaluate operation with CtrlGoTo() to set exactly which control in the subform the user lands on.
The Online and Rich Client Samples projects (program SB03 and RSB03)