Tuesday, September 7, 2010

Cairngorm 2 View Notification

Though Cairngorm 3 is out there by Adobe, many developers still using Cairngorm 2 (Model-View-Controller) framework for their projects. They find a common issue like View notification when a command updates data from any service. There are many ways discussed, to solve this problem. There are different situations which need to handle differently.

  1.  If we are not using objects which dispatches event on update (like ArrayCollection) and we want to inform the view after we got an update form server.
  2.  If we want to notify different views on data update and want to write our custom codes to update the display.

For the first case UniversalMind's CairngormExtension library(open source) provides a better solution. Which helps to update the view which invoked that event. It also gives more extensions to the Basic Cairngorm which is very helpful.
You can find the source code of the library here.

If you are not interested in whole library you can achieve this by creating custom event and custom command.
In the custom event you need to pass an extra argument as responder. That responder will hold the result and fault handlers which will be executed after data updates. The custom command holds the view responder and returns back the data to it. An example with  source code (java + flex) is available here.

We can achieve the same by creating a view object in Modellocator or by application and dispatch events like second case code. However it is not the best practice to do so.

For the second case we can dispatch a custom event by application and handle it from view.
Add the event listeners in creationcomplete method in the views which need update their display like:

protected function group1_creationCompleteHandler(event:FlexEvent):void
{
                // TODO Auto-generated method stub
                 FlexGlobals.topLevelApplication.addEventListener(HelloWorldEvent.SAY_HELLO, handleEvent);
}
           
private function handleEvent(event:HelloWorldEvent):void
{
                  Alert.show(event.msg, "Hurahh");
}


Dispatch the event from command class's result method by application. You can keep your data object in model locator or in event itself.

public function result(data:Object):void
{
            var event:HelloWorldEvent = new HelloWorldEvent(HelloWorldEvent.SAY_HELLO);
            event.msg = data.result;
            FlexGlobals.topLevelApplication.dispatchEvent(event);
  }

No comments:

Post a Comment

Add your Thoughts...