When developing Swing applications, I’ve typically defined a delegate interface for each UI component for action callbacks. For example, if there is a class, MyDialog, which contains a button, MyButton, then the ActionListener for MyButton will call MyDialog.Delegate.OnMyButtonClick(Event e). The UI component then becomes “dumb” and requires a controller to handle events as well as update the component itself.
I thought that by using the Swing Application Framework’s @Actions, I could get around creating delegate interfaces and implementations by defining @Action methods in implementation classes, letting the ApplicationContext figure out what to call. Apparently, that is not the case, as I don’t see any clear way of adding those classes into the ApplicationContext, nor do I see any examples out there of doing such a thing.
Has anyone managed to use SAF in this manner so that there is a clean separation between UI and UI action code?
I’ve discovered a good way to keep the UI separate from the behavior using @Actions.
First, create a UI Component, say a JPanel with a button and then give it a public method that can be used to set the action of the Button:
Next, create an Action class that will provide the logic for that button:
Finally, setup the application controller and during setup, assign the appropriate action to the appropriate UI:
In this way, the UI is logically separated from the control (i.e. Action) and can be tested on its own. The controller can make any decisions it needs to in order to determine what Action set to use and which specific action to assign to the UI controls. That is, one can create a Test Action Set and a Live Action Set, etc.
This method of using SAF has worked rather well for me.