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

mattr

v0.0.5

Published

Custom attributes to extend Mithril's view language

Downloads

6

Readme

Alpha status. Code written off the cuff, untested. Use at own peril.

Join the chat at https://gitter.im/barneycarroll/mattr

What's the mattr?

Mattr allows you to extend the Mithril view language with custom attributes.

UMD compliant, so you can include as a raw script, require using Node or Browserify, or via RequireJS, SystemJS, etc.

How to

w/o modules / package management

<script src="/path/to/mithril.min.js"></script>
<script src="/path/to/mattr.js"></script>
<script>
	m = mattr.m
</script>

In package-managed applications, you must make sure to include Mithril in your package.json: Mattr invokes it internally:

CommonJS (Node, Browserify, etc)

var m = require( 'mattr' ).m

ES6

import { m } from 'mattr'

Custom attributes should be assigned to the attrs property of the Mattr-extended Mithril. For the sake of example, here's a naive but simple custom attribute for bi-di binding:

m.attr.bidi = function( node, value ){
	node.value   = value()
	node.oninput = m.withAttr( 'value', value )
}

// Then in your application code, instead of this:
var password = m.prop()

m( 'input[type=password]', {
	value   : password,
	oninput : m.withAttr( 'value', password )
} )

// ...you'd write this:
var password = m.prop()

m( 'input[type=password]', {
	bidi : password
} )

Custom attributes?

Mithril only has one custom attribute by default – config – which gives you access to the raw DOM element after redraw. The most obvious use case for config is to invoke 3rd party plugins to work on the rendered DOM element: these plugins presumably abstract some complicated task into a simple API so you don't have to write complex DOM functions yourself. But when you want to write a large and ambitious Mithril application, you'll probably encounter all sorts of situations where you want to abstract virtual DOM patterns into plugins. The Mithril blog expands on this idea in more detail.

Mattr offers a generic API for writing such plugins in an idiomatic and painless way.

Custom attribute conflicts

The default scenario for custom attributes is an application codebase where you have full control of what attributes are used. But if you're writing a Mithril component (for example) destined for use in other codebases, there's a risk you might use a custom attribute with the same name as one being used in the external codebase, at which point one will override the other. If you're writing code destined for 3rd party use, you should create a new instance of extended Mithril for use in your application that doesn't infringe on the external codebase.

You can create a new extended Mithril with it's own set of custom attributes by using the core API function:

// Closures are used to demonstrate scope isolation
( function plugin(){
	// Attributes can be passed in directly:
	// They will still be available @ m.attr
	var m = mattr( {
		bidi : bidiTransform
	} )
}() )

// Later, in the user's code...
m.attrs.bidi = usersOwnBidiPlugin