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

bobtail-json-cell

v0.3.1

Published

This package is intended to provide an easy, way to use functional reactive programming to deeply nested JSON objects. Built on the [bobtail](github.com/bobtail-dev/bobtail) reactive programming framework

Downloads

1

Readme

README

This package is intended to provide an easy, way to use functional reactive programming to deeply nested JSON objects. Built on the bobtail reactive programming framework

See the bobtail-form package, which uses JsonCells to for its reactive form serializaiton, for a sample use case.

Example code in this README is written in CoffeeScript.

The Problem

...

Usage

Instantiation

// equivalent
obj = jsonCell {x: y: z: 1}
obj = new JsonCell({x: y: z: 1}).data

Dependencies and mutation events

Getting a field (obj.x.y), or checking to see if a key is present ('z' in obj.x.y). Note that in the latter example, a 'get' dependency has been introduced on obj.x and obj.x.y, as well as the 'has' dependency on obj.x.y.z. Setting a field (obj.field = 'foo', obj[fieldVar] = 'bar') will trigger a mutation event, as will using the delete keyword.

API

class JsonCell

The most important thing here at the moment is the data field. This is the Proxy object which overlays the underlying data and handles all of the reactive bits. The data cell is itself behind a setter, which patches the data object and fires all necessary events. Thus, you can do things like this:

c = new JsonCell {} 
x = bind -> c.data.x
# x.get(): undefined
c.data = {x: 1}
# x.get(): 1

More to come...

function jsonCell(obj)

Constructs a JsonCell from obj, and returns its data field.

More to come...

Example

{jsonCell} = require 'bobtail-json-cell'
rx = require 'bobtail-rx'
myRxJson = jsonCell a: b: c: {'d', 'e', 'f'}
abc = rx.bind -> myRxJson?.a?.b?.c
# abc: {d: 'd', e: 'e', f: 'f'}
rx.snap -> myRxJson.a.b.c = 1  # snap necessary because otherwise we would introduce dependencies on a and a.b
# abc: 1
rx.snap -> delete myRxJson.a
# abc: undefined
myRxJson.a = b: c: d: 42
# abc: {d: 42}

myArr = new JsonCell([0, 1, 2]).data
depArr = rx.bind -> myArr
depLen = rx.bind -> myArr.length
myArr.push 3
# depArr: [0, 1, 2, 3], depLen: 4
myArr.shift()
# depArr: [1, 2, 3], depLen: 3

Implementational Details

Diffing and Patching

Because this package is specifically intended for working with complex JSON, mutation is handled by patching existing portions of the object tree, to attempt to minimize mutations. Diffing and patching are handled by Benjamín Eidelman's jsondiffpatch package.

In particular, this means that the = operator behaves differently with JsonCells than regular objects. Consider myRxJson = jsonCell a: b: c: {'d', 'e', 'f'}, from above. If we were to execute myRxJson.a.b = {c: 'd', 'e', 'f'}, nothing would happen. That's because we are attempting to replace myRxJson.a.b with an identical object. jsondiffpatch will see this, and do nothing. Now consider myRxJson.a.b.c = {'d', f: 'z'}. Rather than replacing myRxJson.a.b.c with a new object, under the hood, jsondiffpatch will be doing something like a.b.c.f = 'z'; delete a.b.c.e;.

This helps cut down on unnecessary refreshes, since bobtail uses reference equality to determine if a refresh is necessary, and ensures that dependencies do not wind up pointing at "orphaned" objects, which would be a risk if we simply compared diffs before doing a regular assignment.

Null Checking

When working with nested JSON objects, some kind of null-checking is highly useful. CoffeeScript's ? operator is incredibly helpful. For those not using CoffeeScript, I recommend using Jason McAffee's nevernull package. Alternatively, you can use Lodash's suite of object utilities, which offers a number of utilities for deep access on objects.

Proxies

This project is dependent on Proxies. Proxies are supported on the latest versions of Edge, Chrome, Firefox, and Safari. However, many older browsers, including Internet Explorer, do not support them, and they cannot be polyfilled.

As such, if you need your code to work on older browsers, you should not use this package.

Installation

Run npm install bobtail-json-cell.