- collection events bound with
on({collection: events})
no longer recieve aCollectionView
as the first argument as collections may be bound without aCollectionView
- added
bindCollection
andunbindCollection
addModel
andremoveModel
renamed tobindModel
andunbindModel
empty-context
incollection
helper now defaults toparent.context
- Revert: DOM event handlers now recieve the original context (if the handler had been registered with $.on) as the second argument
expand-tokens=true
is now required in theurl
helper to expand handlebars tokens inside a url- Added
loading-placement
option to thecollection-helper
- DOM event handlers now recieve the original context (if the handler had been registered with $.on) as the second argument
- Added bower support
- Add
trigger
attribute option to button and link helpers - Fail silently when #view helper does not find a view instance (1.x behavior)
$.model
now accepts a view as an optional argumentThorax.View.prototype._loadTemplate
renamed toThorax.Util.getTemplate
- add
template
helper block capture andyield
variable - added
Thorax.onException
hook for easier android debugging - collection
filter
option now hides or shows elements instead of adding or removing them - collection
filter
option now applied when model change event is triggered - collection event change: when using view.on({collection: events}) syntax,
CollectionView
instances are now prepended to the array of arguments passed and the callback is now called with the context of the delcaring view - allowed creation of
CollectionView
classes in JavaScript direclty (previously could only be created via the collection helper) Thorax.Router
andThorax.ViewController
now use a constructor override so that super.initialize() does not need to be invoked when overridinginitialize
- added mobile plugin
- allow nested objects in any registry to allow: {{view "Nested.Object"}}
thorax build
command now requires a target filename as the first argumentThorax.Util.shouldFetch
will now gracefully support Backbone.Model and Backbone.Collection instances- allow Backbone.Model and Backbone.Collection instances to be passed to
_loadModel
and_loadCollection
item-context
andempty-context
will try to useitemContext
andemptyContext
functions as defaults if they are available on the declaring view- a build system was created, some method overrides are now done via code templates with handlebars instead of in JS, resulting in smaller wire size and less computational overhead
- added
build
command - thorax.lumbar plugin was removed, functionality was moved to boilerplate projects
Application
class was removed, functionality was moved to boilerplate projects- registry methods (
Thorax.view
,Thorax.model
, etc) were removed,name
property now has special meaning when passed toextend
methods such asThorax.View.extend
Thorax has been split into a variety of plugins for a better separation of concerns, the base thorax.js file now only deals with Backbone + Handlebars integration.
-
template has been renamed to renderTemplate
-
templates may now be specified as part of the class definition as a string via the
template
attribute -
Thorax.configure() has been removed and repalced with an Application class, the equivelent code would be:
var Application = new Thorax.Application(); Application.start(historyOptions); $('body').append(Application.el);
-
scrollTo and scrollToTop have been removed and will appear in the mobile plugin in 2.1
-
Handlebars.registerViewHelper has been added.
empty
,collection
and other view helpers are all implemented in this manner -
addition of
$.view, $ .model and $.collection
Mixin behaviors have been moved to the mixin plugin.
All data loading functionality, including flushQueue, fetchQueue, bindToRoute and load() have been moved into a separate thorax.loading.js file. In addition the collection helper accepts two new arguments when this file is present:
- loading-view
- loading-template
Which insert a loading view or template onto the bottom of the collection while the collection is loading. A loading helper is also provided that can be used outside of the collection helper.
The signatures of exisiting methods were not changed and the unit tests for existing functionality were only trivially changed.
- Thorax.View.registerEvents has been renamed to Thorax.View.on and is available on all Backbone and Thorax classes
- Any object that can be used as the Thorax.View.prototype.events object may now be used as an argument to on()
- The nested event keyword has gone away and will re-appear (or have a different implementation accomplishing the same thing) in 2.1
- All view events regardless of how they are registered will now be processed with _addEvent who's signature is unchanged
- Events to be bound on another object only while the view is alive may be registered with: view.on(target, eventName, callback) When the view is destroyed the event on the target object will be unbound.
serialize
, populate
and validateInput
have been moved into a form plugin but are unchanged
Added link
, url
and button
helpers.
Previously all click a
events would trigger the Backbone.history.navigate
behavior. This is now opt in via the link
helper.
Collection handling has been completely re-written and is not backwards compatible. The new collection helper must be used. Multiple collections and multiple displays of the same collection may now be present in the same view. Each collection helper will generate a CollectionView
instance. Specific migrations:
- item-context may be specified in the collection helper instead of setting an itemContext method on the view class
- empty-context may be specified in the collection helper instead of setting an emptyContext method on the view class
- rendered:collection event recieves the related collectionView as it's first argument
- rendered:item event recieves the related collectionView as it's first argument
- rendered:empty event recieves the related collectionView as it's first argument
- renderItem no longer exists on the view class, use the rendered:item event or specify specific behaviors in your item-view class
- renderEmpty no longer exists on the view class, use the rendered:empty event or specify specific behaviors in your empty-view class
- the filter option has been added which should be used in place of the behavior added in https://github.com/walmartlabs/thorax/pull/43/files
A lumbar plugin has been added which adds a module.router() method to each lumbar generated module. The Thorax + Lumbar node boilerplate project makes use of this:
https://github.com/walmartlabs/thorax-boilerplate/tree/master/thorax-node
Thorax.Model
and setModel
have been moved to the model plugin but are unchanged in behavior.
Thorax.Layout
has been renamed toThorax.LayoutView
. It is now aThorax.View
subclass instead of aBackbone.View
. MultipleLayoutView
instances may now be embedded in a parent view.setView
has gained adestroy: false
optionlayout.getView()
must be used to get the current view of a layout instead oflayout.view
Thorax.ViewController
andThorax.Application
classes have been addedroute
androute:before
events have been added toThorax.Router
Have been removed, except for the following command:
thorax templates ./templates-dir ./templates.js
Boilerplate projects have been provided and a lumbar.json editor will appear in 2.1
- load:start and load:end handling have been moved into a plugin
- nested event keyword now works with views, the callback will always be called with the context of the declaring view and will always recieve the triggering view as the first argument
- empty() the collection element before renderCollection()
- added {{collection}} helper
- _collectionSelector is now deprecated and internally defaults to [data-collection-cid], for backwards compatibility set it to ".collection" in your view classes
- added templatePathPrefix option to configure()
- unit tests!
- added nested event keyword
- added _addEvent method for subclasses to customize event registration
- registerEvents is now an instance method in addition to a class method
- added emptyContext method, called from renderEmpty
- checks for view.name property are now lazy
- exceptions are now thrown instead of using console.error