Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/whitered/Kote
Kote is a fast and lightweight MVC framework for ActionScript 3 that brings together the best of PureMVC and as3-signals
https://github.com/whitered/Kote
Last synced: about 2 months ago
JSON representation
Kote is a fast and lightweight MVC framework for ActionScript 3 that brings together the best of PureMVC and as3-signals
- Host: GitHub
- URL: https://github.com/whitered/Kote
- Owner: whitered
- License: mit
- Created: 2010-01-29T14:14:43.000Z (almost 15 years ago)
- Default Branch: master
- Last Pushed: 2013-03-18T23:12:45.000Z (almost 12 years ago)
- Last Synced: 2024-08-04T05:02:58.800Z (5 months ago)
- Language: ActionScript
- Homepage: http://wiki.github.com/whitered/Kote/
- Size: 844 KB
- Stars: 3
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.textile
- License: MIT-LICENSE.txt
Awesome Lists containing this project
- awesome-actionscript-sorted - Kote - Kote is a fast and lightweight MVC framework for ActionScript 3 that brings together the best of PureMVC and as3-signals (Frameworks / MVC Framework)
README
*Kote* is a lightweight and easy to use MVC framework for ActionScript and Flex.
Kote brings together the best features from "PureMVC":http://puremvc.org and "as3-signals":http://github.com/robertpenner/as3-signalsh2. Overview
h3. Notification
p. Notification represents an event that occure in your application.
h3. Facade
p. Facade is the central part of the framework. It manages mediators, proxies and commands. This is a good place to list your notifications.
bc.. public class ApplicationFacade extends Facade
{
public static const CHAT_MESSAGE_RECEIVED:Notification = new Notification("chat message received");
public static const SEND_CHAT_MESSAGE:Notification = new Notification("send chat message");public function ApplicationFacade()
{
addCommand(SEND_CHAT_MESSAGE, new SendChatMessageCommand());addProxy(new ChatServiceProxy());
addMediator(new ChatLogMediator());
}
}h3. Command
p. Commands are the *controller* of your application. Any command is an object that handles notification. This is part of controller of your application. Typical command has @run()@ method which accepts arguments that were specified when the notification sent.
bc.. public class SendChatMessageCommand extends Command
{
public function run(receiver:Person, message:String):void
{
ChatService.instance.pushMessage(receiver, message);
}
}p. Now we can send a notification like this:
bc. sendNotification(ApplicationFacade.SEND_CHAT_MESSAGE, myCat, "Hello, Kote!");
p. Command can also abort notification. When notification aborted, no more commands will be executed and subscribed mediators will not receive it.
p. To abort notification override command's @execute()@ method to return false:
bc.. override public function execute(notificationObject:NotificationObject):Boolean
{
notificationObject.parameters = ["this notification is aborted"];
return false;
}p. Note that argument type of execute() method is NotificationObject, which allow to change notification parameters.
h3. Proxy
p. Proxy represents a *model* of your application.
bc.. public class ChatServiceProxy extends Proxy
{
public function pushMessage(receiver:Person, message:String):void;
}p. When @ChatServiceProxy@ receives a message from server, it can send a notification:
bc.. private function handleServerMessage()
{
sendNotification(ApplicationFacade.CHAT_MESSAGE_RECEIVED, myCat, "Kote atakue!");
}h3. Mediator
p. Mediators represent *view*. A mediator usually controls a visual object. It can subscribe for notifications.
p. To handle a notification in mediator subscribe for it and create a handler function:
bc.. public class ChatLogMediator extends Mediator
{public function ChatLogMediator()
{
subscribe(ApplicationFacade.CHAT_MESSAGE_RECEIVED, handleChatMessage);
}private function handleChatMessage(sender:Person, message:String):void
{
// show message
}
}p. Note that each handler should accept the same type of arguments that were passed to the notification.
p. Notifications also have signals (similar to "Robert Penner's as3-signals":http://github.com/robertpenner/as3-signals):
* @onSubscribe@
* @onUnsubscrive@
* @onAdd@
* @onRemove@p. To listen for a singnal just add listener for it:
bc.. public function ChatLogMediator()
{
onSubscribe.addCallback(handleSubscribe);
onRemove.addCallback(handleRemove);
}private function handleSubscribe(mediator:Mediator, notification:Notification):void
{
trace("Mediator has subscribed for", notification);
}private function handleRemove(mediator:Mediator, facade:Facade):void
{
trace("Mediator was removed from facade", facade);
}