/pointers

Syncs a model or collection with an element. Supports two-way syncs. Respects garbage collection and bottom-up rendering. Reactive.

Primary LanguageCoffeeScriptOtherNOASSERTION

Pointers

Build Status NPM version Gittip donate button Flattr donate button PayPayl donate button

Syncs a model/collection with an element. Supports two-way syncs. Respects garbage collection and bottom-up rendering. Reactive.

Install

  • Use: require('pointers')
  • Install: npm install --save pointers
  • Use: require('pointers')
  • Install: npm install --save pointers
  • CDN URL: //wzrd.in/bundle/pointers@1.1.3
  • Use: require('pointers')
  • Install: ender add pointers

Demo

View the interactive JSFiddle

Usage

Element Sync comes in handy when you want to keep an element up to date with a model or collection, or a model up to date with the value of an element, or both.

There are three ways you can keep sync a model or collection to an element:

  • You can keep an element's text or value up to date with the value of a model's attributes
    • Uses the element item, and itemAttributes configuration options
  • You can keep an element up to date with a view bound to the model
    • Uses the element, and item configuration options
  • You can keep an element up to date with views for each model in a collection
    • Uses the element, item, and viewClass configuration options

And there is one way you can sync an element to a model or collection:

  • You can keep a model's attributes value up to date with an element's value or text
    • Uses the element, item, itemAttributes, and itemSetter configuration options

The only differences between these methods, are what configuration options are sent to the pointer. The available configuration options are:

  • item — the model or collection that we want to sync with the element, e.g. new Backbone.Model()
  • itemAttributes — when syncing a model's attributes to an element, this is an array of the attributes that we want to sync to the element's value, e.g. ['title', 'name', 'path']
  • viewClass — when syncing a model or collection directly to an element, this is the view class that be instantiated for the model, or for each of the collection's models
  • element — the element to our collection, model, or specified model's attributes to
  • elementSetter — when syncing a model's attributes to an element, this is either true to use the default setter that will update the element's value or text, or can be a custom function that accepts an object of $el the element, item the item this pointer is for, value the model value that just changed
  • itemSetter — when syncing an element's value to a model's attribute, this is either false to disable this ability (the default), true to use the default setter (just a plain set of the first specified itemAttribute using the element's latest value), or a function that accepts an object of $el the element, item the item this pointer is for, value the element value that just changed

Knowing all this, you create a pointer like so:

var Pointer = require('pointers').Pointer;

new Pointer({
	item: null,
	itemAttributes: null,
	viewClass: null,
	element: null,
	elementSetter: null,
	itemSetter: null
}).bind()

Compatibility

Elements

Pointers are compatible out of the box with both jQuery and Zepto, and whatever else that implements the API:

  • $el = $(domElement)
  • $el.data('property'), $el.data('property', value)
  • $el.addClass('className')
  • $el.appendTo($anotherEl)
  • $el.find('sizzle selector')
  • $el.children()
  • $el.each(function(){})
  • $el.is('sizzle selector')
  • $el.val('value')
  • $el.text('html that will be escaped to text')
  • $el.on('change', function(event){})

Views

Pointers are compatible out of the box with MiniView, or whatever else that implements the API:

  • new viewClass({item: item, model:item}) — the constructor of the view class should either accept the model via the item or model configuration options
  • view.destroy() — a method to remove the element from the DOM, and clean up the view from memory
  • view.$el — exposes the element that the view is for

Which can be easily accomplish with Backbone.js Views and SpineMVC Controllers.

Models

Pointers are compatible out of the box with Backbone Models, and whatever else that implements the API:

  • model.get('name') — get an attribute value
  • model.set({name: "Benjamin Lupton"}) — updates the attributes on the model
  • model.on('change:name', function(theSameModel, theNewValue, someOptions){})
  • model.off('event', listenerFunction)

Collections

Pointers are compatible out of the box with Backbone Collections, and whatever else that implements the API:

  • collections.models — an array of model instances
  • collection.on('add', function(addedModel, theSameCollection, someOptions){})
  • collection.on('remove', function(removedModel, theSameCollection, someOptions){})
  • collection.on('reset', function(theSameCollection, someOptions){})
  • model.off('event', listenerFunction)

History

Discover the change history by heading on over to the HISTORY.md file.

Contribute

Discover how you can contribute by heading on over to the CONTRIBUTING.md file.

Backers

Maintainers

These amazing people are maintaining this project:

Sponsors

No sponsors yet! Will you be the first?

Gittip donate button Flattr donate button PayPayl donate button

Contributors

These amazing people have contributed code to this project:

Become a contributor!

License

Licensed under the incredibly permissive MIT license

Copyright © 2013+ Bevry Pty Ltd us@bevry.me (http://bevry.me)