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

autotroph

v1.1.1

Published

a simple ES5 flux library

Downloads

2

Readme

autotroph

A simple Flux implementation without any build requirements or dependencies. This is easier to learn, but for real projects you should consider Redux instead!

Getting Started

This library is just an autotroph module with some properties: dispatch and other methods are based on the Flux reference dispatcher, and createStore is a helper function for creating simple stores that will receive dispatched actions.

Stores

The output of a call to autotroph.createStore() is an object that has .subscribe(), .unsubscribe(), and .getState() functions. Subscribe your render function to these stores, and then pass your action objects to autotroph.dispatch().

initialState

The first argument to autotroph.createStore() is an object with the initial values of your state variables. This object will be passed into the actionHandler along with every action that is dispatched. By default changes are saved by mutating this object, and you are responsible for adding any immutable behavior. You can assign immutable references to any property on initialState, or make initialState an array of historical state objects.

actionHandler

The second argument to autotroph.createStore() is a function that takes the current state and the action object as arguments, and returns true if the app should re-render. Check the action and either update the state or make a new immutable version in this handler. In most cases this function will return true, but you can return false to skip re-rendering.

Example

See test.html for a usage example. This file can be downloaded and run locally in most browsers with no setup.