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

backbone-collection-search

v0.2.1

Published

A keyword search plugin for Backbone.Collections

Downloads

3

Readme

Backbone.Collection.search

A keyword search plugin for Backbone.Collections

This plugin adds a "search" method to allow keyword search through the model's attributes in the collection. This is a great plugin for implementation of typeahead widgets.

How to use

collection.search( [query string] );

collection.on('search', function( results ) { ... });

search

collection.search( [query string], [array of attributes] )

Search requires a query string and accepts an optional attributes parameter. All the attributes will be searched from each model unless you provide an array of attributes. When the results are ready, a trigger "search" will fire and a new collection of the models are returned.

var Book = Backbone.Model;
var books = new Backbone.Collection();

books.add(new Book({ author: 'J. K. Rowling', related: 'Stephanie Meyer books', title: 'Harry Potter #1' }));
books.add(new Book({ author: 'P&B Pollack', related: 'Stephanie Meyer books', title: 'Who Is J. K. Rowling?' }));
books.add(new Book({ author: 'Stephanie Meyer', related: 'J. K. Rowling books', title: 'Twilight'}));

books.search('rowling', ['author','title']);

books.on('search', function( results ){ alert( results.pluck('title') ) });
// Will result: "Harry Potter #1,Who Is J. K. Rowling?"
books.search('rowling');

books.on('search', function( results ){ alert( results.pluck('title') ) });
// Will result: "Harry Potter #1,Who Is J. K. Rowling?,Twilight"

matcher

collection.matcher( needle, haystack )

matcher is used to test the query against the attribute value. In the given default method, the search is doing a simple "indexOf" string search. It returns true if it finds a match. This can be customized to a more robust matcher if desired (i.e. RegExp). In theory you may use different object types, but the provided method is dealing with strings.

getSearchResults

collection.getSearchResults()

This will return the most recent queried results. The resulted collection also has a method getSearchQuery() to get the search query used to get that result.

books.on('search', function(){ 
  var results = this.getSearchResults();
  
  alert( results.pluck('title') )
  // Will result: "Harry Potter #1,Who Is J. K. Rowling?"
  
  alert( results.getSearchQuery() )
  // Will result: "rowling"
});

getSearchQuery

collection.getSearchQuery()

This will return the most recent search query. It will pull directly from getSearchResults()

As a simple utility filter

Like the built in underscore methods, it returns the collection. Note: this won't work with the ajax version.

var stephanieBooks = books.search('stephanie', ['author']);

alert(stephanieBooks.pluck('title'))
// Will result: "Twilight"

Ajax version

backbone-collection-search-ajax.js

If a front-end solution doesn't suffice, there is also an ajax support using the fetch function and ability to add parameters. This is a starter piece to making that server-side search function. The mark up on the front-end will be exactly the same, and it will similarly fire 'search' when the call is finished. The appended parameters are keyword and attributes[]

GET http://somelibrary.com/api/books?keyword=rowling&attributes[]=author&attributes[]=title

Non-destructive plugin

The plugin is non-destructive to all the existing behaviors.

Prerequisites

  • Backbone v1.0
  • Underscore v1.4

How to load

Require.js AMD

require.config({
  paths: {
    'underscore': 'assets/js/underscore',
    'backbone': 'assets/js/backbone',
    'backbone-collection-search': 'assets/js/backbone-collection-search',
    'backbone-collection-search-ajax' : 'asset/js/backbone-collection-search-ajax'
  },

  shim: {
    'backbone': {
      deps: ['underscore'],
      exports: 'Backbone'
    },
    'backbone-collection-search': {
      deps: ['underscore', 'backbone'],
      exports: 'Backbone'
    },
    'backbone-collection-search-ajax': { 
      deps: ['underscore', 'backbone'],
      exports: 'Backbone'
    }
  }
});
define(['backbone-collection-search'], function( Backbone ) {  ...  });
  OR
define(['backbone-collection-search-ajax'], function( Backbone ) {  ...  });

Static

<script src="assets/js/underscore.js"></script>
<script src="assets/js/backbone.js"></script>
<script src="assets/js/backbone-collection-search.js"></script>
  OR
<script src="assets/js/backbone-collection-search-ajax.js"></script>

Versions

v0.2.1

Streamlined the way to retrieve the recent query's keyword and attribute

  • getSearchQuery() now returns an object from the defined "searching" object literal in the new collection

v0.2

Code needed some love and refactoring so I had to make the changes

  • Removed delay because I thought it was unnessary. Any delay (like for a typeahead widget) should be done in the View.
  • Added a way to return the collection without needing to wait for the trigger as a utility filter.
  • Added AJAX version as a starter piece to making a server-side search.

v0.1

  • First commit!