npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

behave-collection

v0.1.0

Published

A collection class to simplify working with BehaveImmutable instances

Downloads

4

Readme

behave-collection

A collection class to simplify working with BehaveImmutable instances

Codeship Status for behavejs/behave-collection

BehaveImmutable models have a lot of great features but working with groups of them can be tough, BehaveCollection strives to make this a trivial thing.

If you are not familiar with the concepts of BehaveImmutable models then I would suggest reading up on them first. This will help you understand the API of BehaveCollection.

Install

npm install --save behave-collection

Usage

import BC from 'behave-collection';
import BI from 'behave-immutable';

let collection = new BC([
    new BI({ some: 'value' }),
    new BI({ another: 'value' }),
    new BI({ arr: [1, 2, 3] })
]);

/* accessing models */
collection.at(0).toJS();
// => { some: 'value' }

collection.range(0, 2);
// returns array of models in range (includes end index model)
// => [BehaveImmutabe, ..., BehaveImmutable]

collection.find({ some: 'value' });
// returns array of models containing values given
// => [BehaveImmutabe] || []

collection.findWhere({ some: 'value' });
// returns first model containing the values given
// => BehaveImmutabe || undefined

/* iterating over the collection */
collection.each(m => m.set({ updated: true }));
// => BehaveCollection

var rawJS = collection.map(m => m.toJS());
// => [{some: 'value'}, {another: 'value'}, {arr: [1, 2, 3]}]

var filteredModels = collection.filter(m => m.get().get('some') === 'value');
// get latest version of data, get `some` property from that data

/* quick extraction of collection data */
collection.toJS();
// => [{ some: 'value'  }, { another: 'value' }, { arr: [1, 2, 3] }]

collection.toJSON();
// => [{ "some": "value" }, { "another": "value" }, { "arr": [1, 2, 3] }]


/* altering the collection */
collection.add(new BI({ model: true }));
// adds a model to the collection, fires add event unless opts.silent is true

var batched = collection.batch([
    new BI({ some: 'value' }),
    new BI({ another: 'value' }),
    new BI({ arr: [1, 2, 3] })
]);
// returns array of added models, fires add event for each model unless opts.silent is true

var removed = collection.remove(collection.at(0)._id);
// removes a model from the collection, fires remove event unless opts.silent is true

collection.purge();
// remove all models from the collection

collection.count();
// get count of models

Testing

Run npm install and then run npm test.

Release History

  • 0.1.0 Initial Release