Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/krange/AS3-Bootstrap

Bootstrap utility for ActionScript 3 and Flex
https://github.com/krange/AS3-Bootstrap

Last synced: about 2 months ago
JSON representation

Bootstrap utility for ActionScript 3 and Flex

Awesome Lists containing this project

README

        

Bootstrap
=======

# Introduction

Bootstrap is a Flex 3/4 and AS3 utility which accelerates development when loading common startup load processes within an application. It was initially built in an agency environment with the purpose of simplifying localized application startup development. It is available currently as either integrated into multi-core PureMVC application or as a standalone utility. Robotlegs is intended to be fully supported but is not quite completed as of this writing.

Bootstrap uses AS3 Signals for dispatching of all events. The PureMVC version is also built upon the PureMVC Fabrication utility which adds many useful features to typical PureMVC programming syntax as well as simpler integration when building modular applications.

In the Downloads section you will find SWCs built currently for the 3.6.0 and 4.1.0 Flex SDKs. I will be adding additional SDK builds once I get a chance to test. If you require a different SDK, you can download the source and add SDKs via the ANT script.

## Dependencies

The following dependencies are required and not directly built into the release SWCs to provide the user the ability to use different versions if needed.

All versions:

* [AS3 Signals](https://github.com/robertpenner/as3-signals/) - version 0.8 or higher

For PureMVC applications, the following are required:

* [PureMVC](http://trac.puremvc.org/PureMVC_AS3_MultiCore) - Multi-Core
* [Fabrication](http://code.google.com/p/fabrication/)
* [Pipes](http://trac.puremvc.org/Utility_AS3_MultiCore_Pipes)

## What does Bootstrap provide?

The main function of Bootstrap is to simplify the process to load common external resources through an XML file. It also provides the user with a few helpful additional utility classes like integrating preloaders in Flex as well as progress classes integrated with the load.

The following resources can be loading via XML:

* external CSS (AS 3.0) and CSS SWF (Flex) files
* external font files (including bitmap font SWFs via the Flash IDE)
* external localization XML files

# Configuration Setup

## Flash Vars

The following Flashvars variables are available for use with Bootstrap:

- **baseUrl** – The base URL to load all Bootstrap resources from. This allows you to load correctly when moving throughout the lifecycle of your project from development,staging and production environments. If you provide no baseUrl, Bootstrap will load based on whatever URL you provide in the XML.
- **configXmlBaseUrl** – The base URL to your configuration XML file. Sometimes this might be on a different location entirely than the rest of your assets. If you provide no configXmlBaseUrl then Bootstrap will load based on the URL you provide as the configXmlUrl.
- **configXmlUrl** – The URL to where your configuration XML file lives. This property also supports localized URLs through the flashvars *lang* and *locale* properties.
- **lang** - The language specified for the application for localization purposes through specifying a **{lang}** parameter.
- **locale** - The locale specified for the application for localization purposes through specifying a **{locale}** parameter.

## XML Setup

The Bootstrap utility loads up a configuration external XML file. This file defines all the values that this utility will require to load. The XML can have as many as little of each item as you need. This XML can include other data as well, but the only values that this utility looks for inside the root node are below.

Please note that if you pass in a *baseUrl* flashVar parameter, Bootstrap will apply it as the base of the URLs for the below resources.

- **stylesheet** – Reference to your externalized CSS file or SWF-Compiled CSS (Flex) file. This property also supports localized URLs through the flashvars *lang* and *locale* properties.

```

```

- **font** – Reference to your externalized SWF compiled font file. The *name* property here **optional** if you are registering the font in your font SWF. If you want Bootstrap to register the font for you, the *name* property is the fully-qualified path of the font class (ex. as3bootstrap.fonts._Arial ). This property also supports localized URLs through the flashvars *lang* and *locale* properties.

You can also reference a externalized Flash IDE SWF with bitmap fonts embedded using the same method as currently it's impossible to compile bitmap fonts from outside the Flash IDE.

```

```

- **localization** – In most cases, projects are updated via the clients. Because of this, localization must be updatable via external resources. Bootstrap can load in external XML files to which the content through a value object in name/value pairs. This property also supports localized URLs through the flashvars *lang* and *locale* properties.

```

```

# Getting Started

Getting the basic setup in standalone is as simple as a few lines of code. PureMVC requires writing two classes. See simple examples below. More robust example projects are coming!

## Standalone Mode

```as3
var bootstrap:IBootstrap = new Bootstrap();
bootstrap.bootstrapLoaded.add( onBootstrapLoaded );
bootstrap.start( loaderInfo.parameters );

function onBootstrapLoaded():void
{
// All bootstrap loading has completed
}
```

## PureMVC AS3 Mode

### Main Application

```as3
package as3bootstrap.demo.as3
{
import as3bootstrap.demo.as3.controller.FlStartupCommand;

import org.puremvc.as3.multicore.utilities.fabrication.components.FlashApplication;

public class Main
extends FlashApplication
{
override public function getStartupCommand():Class
{
return FlStartupCommand;
}
}
}
```

### Startup Command

```as3
package as3bootstrap.demo.as3.controller
{
import as3bootstrap.demo.as3.view.ApplicationMediator;

import org.puremvc.as3.multicore.utilities.as3bootstrap.flash.controller.BootstrapFlashStartupCommand;

public class FlStartupCommand
extends BootstrapFlashStartupCommand
{
override protected function getApplicationMediator():Class
{
return ApplicationMediator;
}
}
}
```

### Application Mediator

```as3
package as3bootstrap.demo.as3.view
{
import as3bootstrap.common.progress.IProgress;

import org.puremvc.as3.multicore.interfaces.INotification;
import org.puremvc.as3.multicore.utilities.as3bootstrap.flash.view.mediators.BootstrapFlashMediator;

public class ApplicationMediator
extends BootstrapFlashMediator
{
public static const NAME : String = "ApplicationMediator";

public function ApplicationMediator( name:String, viewComponent:Object, progress:IProgress=null )
{
super( name, viewComponent, progress );
}

override public function respondToBootstrapLoadComplete(notification:INotification):void
{
// All bootstrap loading has completed
}
}
}
```

## PureMVC Flex4 Mode

### Main Application

```as3









```

### Startup Command

```as3
package as3bootstrap.demo.flex4.controller
{
import org.puremvc.as3.multicore.utilities.as3bootstrap.flex.spark.controller.BootstrapFlexSparkStartupCommand;

import as3bootstrap.demo.flex4.view.ApplicationMediator;

public class FxStartupCommand
extends BootstrapFlexSparkStartupCommand
{
override protected function getApplicationMediator():Class
{
return ApplicationMediator;
}
}
}
```

### Application Mediator

```as3
package as3bootstrap.demo.flex4.view
{
import as3bootstrap.common.progress.IProgress;

import org.puremvc.as3.multicore.interfaces.INotification;
import org.puremvc.as3.multicore.utilities.as3bootstrap.flex.common.view.mediators.BootstrapFlexMediator;

public class ApplicationMediator
extends BootstrapFlexMediator
{
public static const NAME : String = "ApplicationMediator";

public function ApplicationMediator( name:String, viewComponent:Object, progress:IProgress=null )
{
super( name, viewComponent, progress );
}

override public function respondToBootstrapLoadComplete( notification:INotification ):void
{
// All bootstrap loading has completed
}
}
}
```

# Access is everything

## Signals/Notifications

The following are the types of events/signals/notifications that Bootstrap will dispatch:

### Standalone

* **bootstrapLoaded** - This signal is dispatched once all bootstrap related loads have completed. At this point you have access to any css, fonts or localization data that was loaded via the bootstrap files.

* **dataLoaded** - This signal is dispatched once all data is loaded. This happens after bootstrapLoaded has been sent. This is only useful if you add additional custom loads via the *IProgress* trackers that are external to what bootstrap is loading. More about this coming soon.

* **appLoaded** - This signal is dispatched once everything in your application has loaded. This happens after dataLoaded has been sent. This is only useful if you add additional custom loads via the *IProgress* trackers that are external to what bootstrap is loading. More about this coming soon.

* **configLoaded** - This signal is dispatched once the config XML file is loaded. It allows the ability to retrieve and react to this data before any additional information is loaded in Bootstrap.

* **configErrored** - This signal is dispatched once the config XML file has recieved a load error. The error event is passed as a paramter.

* **bootstrapErrored** - This signal is dispatched once one of the bootstrap resources to be loaded has recieved a load error. The error event is passed as a paramter.

### PureMVC

* **bootstrapLoadComplete** - Same as *bootstrapLoaded* in Standalone mode, just sent as a *INotification* instead.

* **dataLoadComplete** - Same as *dataLoaded* in Standalone mode, just sent as a *INotification* instead.

* **applicationLoadComplete** - Same as *appLoaded* in Standalone mode, just sent as a *INotification* instead.

* **bootstrapConfigLoadComplete** - Same as *configLoaded* in Standalone mode, just sent as a *INotification* instead.

* **bootstrapConfigLoadFail** - Same as *configErrored* in Standalone mode, just sent as a *INotification* instead.

* **bootstrapLoadError** - Same as *bootstrapErrored* in Standalone mode, just sent as a *INotification* instead.

## Accessing Data

So, now that we've covered the notifications are sent out, how do I really access everything?

In both Flash and Flex applications, accessing the information is the same except for in relation to CSS data. In Flex, when a CSS SWF is loaded in, it is automatically applied to the StyleManager so no Bootstrap specific hook is provided. Also, note that Fonts are registered (if not done so already by your font SWF), so using them is as simple as using the stylesheet or creating a TextFormat and specifying the font name/family you would like to use.

### Standalone

```as3
var stylesheet : StyleSheet = bootstrap.stylesheetModel.stylesheets;
var localization : ILocalization = bootstrap.localizationModel.localizations;
trace( localization.getLocalizedValue( "someValue" ) );
```

### PureMVC

In PureMVC, you would just do the following as the *IBootstrap* class is wrapped in a *Proxy*.

```as3
var bootstrapProxy : IBootstrapProxy = retrieveProxy( BootstrapProxy.NAME ) as IBootstrapProxy;
var bootstrap : IBootstrap = bootstrapProxy.bootstrap;
var localization : ILocalization = bootstrap.localizationModel.localizations;
trace( localization.getLocalizedValue( "someValue" ) );
```

## Progress

Progress tracking has been hinted at in earlier sections and bootstrap has the ability to report such tracking not just internally but also for your entire application. Simply, Bootstrap internally tracks resource load totals and dispatches load progress updates. Accessing this information is quite easy.

### Retrieving bootstrap progress

The below example retrieves the progress for bootstrap. *IProgress* instances report progress totals between 0-1. See the class documentation for more information on how they work.

```as3
var bootstrap : IBootstrap = new Bootstrap();
var bootstrapProgress : IProgress = bootstrap.bootstrapProgress;
bootstrapProgress.addEventListener( ResourceProgressEvent.PROGRESS, onProgressUpdate );

function onProgressUpdate( event:ResourceProgressEvent ):void
{
bootstrapProgress.getAmountLoaded();
// or
trace( event.amountLoaded );
}
```

### Using bootstrap to track application progress

Now let's say you want to incorporate this into the progress of your application? To start, you could easily take the information above and incorporate it into your own custom setup and not read any further! But, you could also use the mechanisms built into Bootstrap and use it as a progress tracker for your entire application. Let's first look at how that progress tracking is setup.

Bootstrap is internally setup to automatically allow tracking for your entire startup load of your application, through resources loaded internally in Bootstrap as well as external data and view assets. Note that we are talking about **tracking only**. You will still need to create your own Loaders to load your content.

Bootstrap automatically splits up the load into 2 separate sections: data and view. This is the recommended setup, though you may attach resources however you like.

* Data resources are reserved for any data related resources that you may want to track. All bootstrap resources are tracked as child *IProgress* instances to the data load. This all happens before the view resources are initialized to be loaded.

* View resources are any view related assets like images, videos, etc.

Each time Bootstrap is instantiated, the constructor takes 3 optional *IProgress* parameters. These 3 instances can help track custom items you may want to include in your entire application. If you don't pass in any items, Bootstrap will automatically create them for you!

* **progress** - This parameter is your top-level progress tracker. It allows you to retrieve total progress tracking for all child *IProgress* instances. The *IBootstrap* interface has a provided getter of the same name.

* **dataProgress** - This parameter is a direct child instance of *progress* and allows you to retrieve total progress tracking for all **data** related child *IProgress* instances. The *IBootstrap* interface has a provided getter of the same name.

* **viewProgress** - This parameter is a direct child instance of *progress* and allows you to retrieve total progress tracking for all **view** related child *IProgress* instances. The *IBootstrap* interface has a provided getter of the same name.

Ok. Ok. Enough talk. Let's see this in action!

```as3
var appProgress : IProgress = new Progress();
var customXmlLoadProgress : IProgress = new Progress();
var bootstrap : IBootstrap = new Bootstrap( appProgress );

bootstrap.bootstrapLoaded.addOnce( onBootstrapLoaded );
bootstrap.dataLoaded.addOnce( onDataLoaded );
bootstrap.appLoaded.addOnce( onEntireApplicationLoaded );

bootstrap.addCustomLoadResource( customXmlLoadProgress );
bootstrap.start( loaderInfo.parameters );

function onBootstrapLoaded():void
{
// This will be called first once bootstrap is loaded
// Now we will set our custom xml load progress
customXmlLoadProgress.setAmountLoaded( 1 );
}

function onDataLoaded():void
{
// Now all data loading as completed. Since we have not
// added any view progress tracking, we set the main
// progress tracker to complete which will complete our
// entire application
bootstrap.viewProgress.setAmountLoaded( 1 );
}

function onEntireApplicationLoaded():void
{
trace( "application loaded" );
}
```

Above is an example of adding a custom data load *IProgress* tracker to bootstrap. There is a sugar method called *addCustomLoadResource* which allows adding custom data loads at certain points during the bootstrap process. See the ASDoc for more information on this method. After bootstrap is loaded, we set this custom progress loaded to be completed. This could actually be set at any point, but we will set it here for the purposes of this example. After this is set, the *dataLoaded* Signal is dispatched. Since we are not tracking any view assets in this application, but want to retrieve the progress total of the entire application, we set the main view *IProgress* to be completed. Not setting this will prevent the *appLoaded* Signal from being dispatched.

### Adding child Progress trackers

One of the core concepts of the *Progress* class and *IProgress* interface is the ability to add as many child instances as needed. Each child instance can also do the same, and so on. Then you can pass these instances out or create them at a later point in your Proxies, Mediators, Views, etc and very simply have tracking setup throughout your entire application. Simply, a *IProgress* instance will save a certain amount of the entire tracking load based on the other children attached. It is up to you to set that amount when ready! Below is a very simple example of how this works:

```as3
var progress : IProgress = new Progress();
var viewProgress : IProgress = new Progress();
var someImageAssetProgress : IProgress = new Progress();
progress.addChildLoadable( viewProgress );
viewProgress.addChildLoadable( someImageAssetProgress );

someImageAssetProgress.setAmountLoaded( 1 );
// Now that we have set the image asset progress to be completed, the
// total progress loaded in the top-level progress will also equal one since
// now all progress instances total will equal 1.
trace( progress.getAmountLoaded() ); // Equals 1
```