Collectionize
A lightweight JS model/collection management library, built on top of Lodash.
Installation
bower install collectionize
npm install collectionize
Example Usage
var Things = Collectionize('things');
Things.add({ id: 2, color: 'blue', shape: 'square' });
Things.add({ id: 3, color: 'red', shape: 'circle' });
Things.add({ id: 5, color: 'green', shape: 'polygon' });
Things.add({ id: 6, color: 'blue', shape: 'triangle' });
Things.size();
Things.search({ color: 'blue' });
Things.get({ color: 'blue' });
Things.index({ id: 3 });
Things.update({ id: 3, color: 'yellow' });
Methods
add(obj)
Add an object to the collection.
Things.add({ id: 2, color: 'blue', shape: 'square' });
clientSave()
Save the collection to localStorage. Assumes localStorage exists, meaning there is no bundled polyfill. If the collection includes DOM elements, those are dropped, and functions are converted to strings.
Things.clientSave()
clientLoad()
Load the collection from localStorage. Assumes localStorage exists, meaning there is no bundled polyfill.
Things.clientSave()
Things.flush()
Things.db = Things.clientLoad()
flush()
flush(newCollection)
Flush out or replace the collection.
Things.flush()
get
Alias for the Lodash find
method.
incr(query, property)
Increments the property
number or sets it to zero if it doesn't exist.
Things.incr({ id: 2 }, 'id');
index
Alias for the Lodash findIndex
method.
isEmpty(query)
Returns true
if the filtered query returns empty, otherwise returns false
.
Things.isEmpty({ color: 'yellow' });
length
Alias for the Lodash size
method.
move(oldIndex, newIndex)
Change the order of an object in the collection.
Things.move(1, 2);
remove(query)
Remove all matching elements from the collection.
Things.remove({ id: 3 });
Things.remove({ shape: 'square' });
search
Alias for the Lodash filter
method.
update(obj, property)
Updates all matching objects by property, or adds object if no matches are found.
Things.update({ id: 2, color: 'red' });
Things.update({ shape: 'square', color: 'red' }, 'shape');
Things.update({ color: 'green' }, { color: 'blue' });
Lodash Methods
at
, each
, every
, filter
, find
, findIndex
, findLastIndex
, first
, last
, map
, max
, min
, pluck
, reduce
, reduceRight
, reject
, sample
, size
, shuffle
, some
, sortBy
, where
Collectionize simply decorates your collection with these methods, meaning instead of _.filter(Things, query)
you would write Things.filter(query)
.
Event Methods
on(eventName, fn)
off(eventName)
trigger(eventName)
Events
beforeAdd
Decorate the object before it's added to the collection.
Things.on('beforeAdd', function (thing) {
thing.initialized = true;
});
added
Do something after an object has been added to the collection, such as save the new object on the server.
Things.on('added', function (thing) {
$.ajax({ url: '/thing', type: 'POST', data: thing });
});
beforeUpdate
Decorate the object before it's updated.
Things.on('beforeUpdate', function (thing) {
thing.initialized = true;
});
update
Do something after an object has been updated, such as save the new object on the server.
Things.on('added', function (thing) {
$.ajax({ url: '/thing/' + thing.id, type: 'PUT', data: thing });
});
deleted
Do something after an object has been deleted from the collection, such as delete the object on the server.
Things.on('deleted', function (thing) {
$.ajax({ url: '/thing/' + thing.id, type: 'DELETE' });
});
Running the Tests
npm install
npm test
License
MIT. Copyright © 2016 Andrew Childs.