/backbone.collectionView

Easily render backbone.js collections. In addition to managing model views, this class supports automatic selection of models in response to clicks, and reordering models via drag and drop.

Primary LanguageJavaScriptOtherNOASSERTION

Backbone.CollectionView

For demos see the Backbone.CollectionView home page.

Depends on jQuery and jQueryUI for event handling and sorting, respectively.

Benefits

  • Provides a view that renders a collection of models, updating automatically when models are added or removed.
  • Keeps track of selected model(s) and fires events when the selection is changed.
  • Adds "selected" css class to selected <li> or <tr>, allowing you to easily style selected model views.
  • Supports single and multiple selection through meta-key and shift clicks, just like a multi-SELECT element.
  • Allows a user to reorder the collection by dragging and dropping.
  • Supports changing the currently selected model(s) through up and down arrow key presses.
  • Allows you to filter which models are visible, selectable, and sortable.
  • Integrates with Backbone.Courier out of the box.

Sample Usage

var myCollectionView = new Backbone.CollectionView( {
	el : $( "#listForCollection" ),		// must be a 'ul' (i.e. unordered list) or 'table' element
	modelView : EmployeeView,			// a View class to be used for rendering each model in the collection
	collection : employeeCollection
} );

myCollectionView.render();
myCollectionView.setSelectedModel( employeeCollection.first() );

Options accepted by the CollectionView constructor

  • el : A <ul> or <table> element. If you supply a <ul> element, your modelView's element can be of any type, but if you supply a <table> element, make sure your modelView has elements of type of <tr>.
  • collection : The collection of models to be rendered.
  • modelView : The view constructor that will be used to create the views for each individual model in the collection.
  • selectable : (default: true) Determines whether models in the CollectionView are selectable.
  • clickToSelect : (default: true) In a selectable CollectionView, determines whether mouse clicks should select models as would be appropriate in a standard HTML mutli-SELECT element.
  • processKeyEvents : (default: true) In a selectable CollectionView, determines if the collection view should respond to arrow key events as would be appropriate in a standard HTML multi-SELECT element.
  • selectMultiple : (default: false) In a selectable CollectionView, determines if multiple models can be selected at once.
  • clickToToggle : (default: false) In a selectable CollectionView, determines if clicking a model view should toggle its selected / unselected state. Only applies if selectMultiple == true.
  • sortable : (default: false) Determines if models can be rearranged by dragging and dropping. (jQueryUI required.)
  • emptyListCaption : A string or a function that returns text to be displayed when there are no (visible) model views.
  • detachedRendering : (default: false) When true, all the modelViews are rendered before being added to the DOM to improve performance. If your modelView rendering relies on its location in the DOM (for sizing or other reasons), use the default value of false.

The following options expect a filter function that takes a single parameter, the model in question, and returns true or false.

  • visibleModelsFilter : (default: all models) Determines which models are visible.
  • selectableModelsFilter : (default: all models) In a selectable CollectionView, determines which models are selectable.
  • sortableModelsFilter : (default: all models) In a sortable CollectionView, determines which models are sortable.

Methods and Properties Reference

  • setSelectedModel( modelReference, [options] ) Sets which model(s) are selected. (See discussion below.)
  • getSelectedModel( [options] ) Returns references to the selected model(s). (See discussion below.)
  • setOption( optionName, optionValue ) Updates the value of a configuration option. All constructor options above are valid except el. The CollectionView is automatically re-rendered if necessary.
  • collection The Backbone collection instance that this CollectionView represents.
  • viewManager A Backbone.BabySitter instance that contains the views corresponding to the individual models in the collection. Backbone.Babysitter implements a "view collection" that enables you to, for example, iterate through all the model views, or easily trigger an event on all model views at once. See the Backbone.BabySitter documentation for more information.

setSelectedModel(s) and getSelectedModel(s)

The getSelectedModel(s) and setSelectedModel(s) methods are used to get or set the currently selected models. The methods are able to reference models in a variety of ways. For instance, it is possible to set the currently selected model using the model object itself (the default), the model's cid, or the model's id. The magic is in the by option:

// Returns an array of the selected models
myCollectionView.getSelectedModels();

// Returns an array of the ids of the selected models
myCollectionView.getSelectedModels( { by : "id" } );

// Select model id 2 and model id 4
myCollectionView.setSelectedModels( [ 2, 4 ], { by : "id" } );

// Select the model with cid equal to "c21"
myCollectionView.setSelectedModel( "c21", { by : "cid" } );

// Returns the view object that represents the selected model
myCollectionView.getSelectedModel( { by : "view" } );

As shown in the examples, the plural versions of the methods expect / return an array of "model references", whereas the singular versions expect / return just a single "model reference".

There are four valid values for by option, which correspond to the type of "model reference" expected / returned.

  • "id" : The id of the model.
  • "cid" : The cid of the model.
  • "offset" : The zero-based index of the model in the collection, only counting models that have visible views.
  • "view" : The view that was created to represent the model when the CollectionView was rendered.

If no by option is provided the model object itself is expected / returned. Additionally, the setSelectedModel(s) function accepts one additional option, silent, which, when true, will prevent the selectionChanged event from being fired.

##Events Fired CollectionViews trigger the following events on themselves. You can respond to these events from another view using Backbone's listenTo method. If Backbone.Courier is available, these events are also "spawned" using Courier.

  • "selectionChanged" ( newSelectedModels, oldSelectedModels ) Fired whenever the selection is changed, either by the user or by a programmatic call to setSelectedModel(s).
  • "updateDependentControls" ( selectedModels ) Fired whenever controls that are dependent on the selection should be updated (e.g. buttons that should be disabled on no selection). This event is always fired just after selectionChanged is fired. In addition, it is fired after rendering and sorting.
  • "doubleClick" ( clickedModel ) Fired when a model view is double clicked.
  • "sortStart" Fired just as a model view is starting to be dragged. (Sortable collection lists only.)
  • "sortStop" Fired when a drag is finished, but before the collection is reordered. (Sortable collection lists only.)
  • "reorder" Fired after a drag is finished and after the collection is reordered. (Sortable collection lists only.)

##Styling

How you style the collection view is up to you.

The ul or table element that is used as the collection view's element will be given the collection-list class. Generally you will want to eliminate bullets, etc., from your collection view list elements, which you can do with these "baseline" styles:

ul.collection-list {
  margin: 0;
  padding: 0;
  list-style-type: none;
  outline: none;
  cursor: pointer;
}

When a model is selected, the li or tr element that corresponds to that model will be given the selected class.

You can style the caption created by the emptyListCaption option with the var.empty-list-caption selector. Here are the suggested defaults, which will center the empty list caption text near the top of the collection view.

var.empty-list-caption {
  color: #A0A0A0;
  padding: 30px;
  display: block;
  text-align: center;
  font-style: normal;
  line-height: 1.45;
}

See the the Backbone.CollectionView home page for styling examples.

##Contributing

Contributions are welcome! Please open pull requests against the dev branch.

##Dependencies

  • Backbone.js (tested with v1.0, v0.9.10)
  • jQuery (tested with v1.9.1)
  • jQueryUI - for sorting (tested with v1.10.1)
  • (optional) Backbone.Courier