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 🙏

© 2025 – Pkg Stats / Ryan Hefner

frypan-react-mobx-grid

v0.1.0

Published

A light-weight yet powerful observable component grid with a simple, functional composition style API, in a MobX and React flavor.

Downloads

6

Readme

Frypan

Join the chat at https://gitter.im/nathanboktae/frypan-knockout-grid

A lightweight and powerful data grid for Knockout

SauceLabs Test Status

Features

  • Column sorting
  • Column filtering
  • Searching
  • Automatic Virtualization if needed, with automatic resizing
  • Infinite Scrolling
  • Custom column templates, with built-in one for link rendering
  • Column resizing
  • Column drag and drop reordering
  • Asyncrounous (Remote) data sources
  • Persists and load settings to local storage or anywhere else
  • Dynamic column discovery - an array of objects (or async data function) is all you need to get started
  • No event soup - everything is wrapped in computed observables. Everything just works when your data and options change

API

data

If data is an array or observable array, frypan operates in syncrounous mode - Using this array as the data source, it will automatically sort columns and filter columns based on the searchTerm.

If data is a non-observable function, frypan operates in an asyncrounous mode. Frypan will call this function with the search criteria - searchTerm, what column is sorted on (if any), etc. This function must return a promise that resolves to an array. Frypan will also display loading markup while a request is in flight.

columns

An optional array of objects to specify columns. You may specify any number of optional params:

  • text: If a string, the property to use as the string. If a function, it takes in the row object and index and returns the string to use as the text.
  • link: Similar to text, a string or function to specify the anchor. text will be used inside the anchor in that case.
  • sort: A function to call to sort rows in the table when sorted on. Frypan will invert the results when sorting descending.
  • class: string or function to specify the class on the td.
  • template: the string to use as the template (use instead of text or link). Optionally can be specified in the view (see below).
  • filter: a function that given the column filter, item, and item index, returns true or false if it should be included. See Filtering below.
  • filterTemplate: The template for the column filter UI. See Filtering below.

Additionally columns may be defined in markup using the frypan-column tag like so:

<frypan-column><span class="fruit" data-bind="text: fruit"></span></frypan-column>

You can mix and max column definitions with code and html so that presentation and function can be cleanly separated

var frypanParams = {
  columns: [{
    name: 'fruit',
    sort: (a, b) => a.fruit > b.fruit ? -1 : 1
  }]
}
<frypan-column name="fruit"><span class="fruit" data-bind="text: fruit"></span></frypan-column>

Here the sort function from the view model will be used, and the template from the view will be used on the same column as they are matched via the name attribute on frypan-column.

Additionally, if columns are completely omitted, frypan will automatically create columns based on the properties of the first object in the result set (including asyncrounously!).

See the column tests for more information.

searchTerm

An observable to use to search and filter on properties. Automatic filtering of properties is based on the text option of the column.

Note that Frypan doesn't provide a search UI; thus the ability for the observable to be passed in, wired up to your own custom search UI. This is because there's no natural place to put it inside the table, so it's up to the user where they want it.

resizableColumns

Set truthy (or an observable that is truthy) to enable column resizing (default is off). Resizers will be available in the headers for the user to resize.

reorderableColumns

Set truthy (or an observable that is truthy) to enable column reordering (default is off). The user will be able to click and drag a column to resize it.

When reordering, frypan will add the frypan-move-source class to the column that is being moved, and frypan-move-target the user is hovering over (it will be inserted before this column). Additionally frypan clones the th that the user is dragging and adds a frypan-move-ghost class to it.

minColWidth

Specifies the minimum column width when using resizable columns. Defaults to 40. This cannot be an observable currently.

Filtering

Documentation to come. See filtering tests for now.

Virtualization

Documentation to come. See virtualization tests and the virtualization example for now.

Installation

via bower

bower install frypan-knockout-grid

or via npm

npm install frypan-knockout-grid