Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pederan/Robotlegs-signals-signalMap
Create and map new signals on the fly
https://github.com/pederan/Robotlegs-signals-signalMap
Last synced: about 2 months ago
JSON representation
Create and map new signals on the fly
- Host: GitHub
- URL: https://github.com/pederan/Robotlegs-signals-signalMap
- Owner: pederan
- Created: 2011-02-08T19:36:56.000Z (almost 14 years ago)
- Default Branch: master
- Last Pushed: 2011-02-17T08:24:55.000Z (almost 14 years ago)
- Last Synced: 2024-08-04T05:03:02.523Z (5 months ago)
- Language: ActionScript
- Homepage:
- Size: 159 KB
- Stars: 12
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.textile
Awesome Lists containing this project
- awesome-actionscript-sorted - Robotlegs-signals-signalMap - Create and map new signals on the fly (Frameworks / Signals Framework)
README
h2. SignalMap
Just an idea that I wanted to try out after reading a discussion between @jhooks, @matanube and @mark_star about whether or not to use a signal bus in Robotlegs. Wanted to make a create a helper class for quicker adding and mapping new signals to the application. It should be noted that subclassing or using a signal bus is perfectly fine, but that I wanted make a more automatic way to achieve the same thing.
h3. Rationale
When using as3 signals in Robotlegs you can either subclass the Signal class and map, or use a signal bus. One of the disadvantage of subclassing the Signal class for all your custom signals is that you may need to manually create and map many classes. On the other hand, using a signalbus, breaks the idea of dependency injection where you only should provide your application tiers with what they need. As @jhooks states: "monolithic controllers tend to break SRP and are generally prone to abuse exposing too much to too many actors."
The SignalMap provides a central that creates and maps the signals for you.
h3. Usage
Create a new instance of SignalMap in your main context or your command setup class (map it if you need to access the signal map in other application tiers)
pre. var signalMap:ISignalMap = new SignalMap(injector);
injector.mapValue(ISignalMap, signalMap); //map if you need to access it later for creating more signalsStart creating your signals using the signalMap (you can pass as many parameters as you need). The signals get mapped in the SignalMap.
pre. var signal:Signal = signalMap.createSignal(nameOfSignal:String, parameters);
You can also create and map signals to trigger commands using the SignalCommandMap
pre. var actionSignal:Signal = signalMap.createSignal("actionSignal");
signalCommandMap.mapSignal(actionSignal, ActionCommand);Then to trigger the command you can dispatch the signal:
pre. actionSignal.dispatch();
In your mediator, command or actor inject the signal you need by using the named injection option. The name needs to be the same as used when creating the signal.
pre. [Inject(name="nameOfSignal")]
public var signalName:Signal;Then dispatch the signal somewhere in your code
pre. signalName.dispatch(signalParameters)
See the example files for a working example.
Just to note: The creation and injection of the SignalMap class should probably be baked into the framework so that you don't have to initialize and map it. Wanted to test before doing more work.
Feedback welcomed.