MetricsGraphics.js is a library optimized for visualizing and laying out time-series data. At under 50KB (minified), it provides a simple way to produce common types of graphics in a principled, consistent and responsive way. The library currently supports line charts, scatterplots and histograms as well as features like rug plots and basic linear regression.
A sample set of examples may be found on the examples page. The example below demonstrates how easy it is to produce a graphic. Our graphics function provides a robust layer of indirection, allowing one to more efficiently build, say, a dashboard of interactive graphics, each of which may be pulling data from a different data source. For the complete list of options, and for download instructions, take a look at the sections below.
data_graphic({
title: "Downloads",
description: "This graphics shows Firefox GA downloads for the past six months."
data: downloads_data, \\ an array of objects, such as [{value:100,date:...},...]
width: 600,
height: 250,
target: '#downloads', \\ the html element that the graphic is inserted in
x_accessor: 'date', \\ the key that accesses the x value
y_accessor: 'value', \\ the key that accesses the y value
})
While we are currently using semantic versioning, you should consider v0.* to have commits that will break things if you are external to Mozilla. This library is in its pre-Cambrian period of wild ideas, and parts of the API will slowly but surely become solidified as we use this more and more internally.
Though originally envisioned for Mozilla Metrics dashboard projects, we are making this repository public for other to use, knowing full well that we are far from having this project in good-enough shape. Take a look at the issues to see the milestones and other upcoming work on this repository. We plan on having fuller documentation in the next milestone, as well as a guide to how to contribute to the library in a way that makes us feel warm inside when we accept your pull request.
- Download the latest release from here.
- Follow the examples in index.htm and main.js to see how graphics are laid out and built. The examples use json data from /data, though you may easily pull data from elsewhere.
The library depends on D3 for binding data to DOM elements, Bootstrap to facilitate layout and jQuery, which we're currently using to facilitate DOM manipulations.
We're grateful for anyone wishing to contribute to the library. Feel free to fork the project and submit your changes as Pull Requests. If both of us r+ the Pull Request, we'll merge it into the master branch.
Changes should be made to the files under src
rather than to js/metrics-graphics.js
. Please use dev.htm
to test changes locally. At least once a release, we regenerate the raw and minified versions of js/metricsgraphics.js
.
- Copy over any changes made in
dev.htm
toexamples.htm
- Run
make.py
- Commit newly generated
js/metricsgraphics.js
andjs/metricsgraphics.min.js
files andexamples.htm
(if applicable) with a message such as, “v0.5 prepared files for release” - Deploy all files to metricsgraphicsjs.org
The download package includes everything that you see on metricsgraphicsjs.org. In order to use the library in your own project, the only files that you'll need are:
- js/metricsgraphics.min.js
- css/metricsgraphics.css
- css/metricsgraphics-dark.css
- images/missing-data.png
- images/missing-data-dark.png
Remember to include the calls to the third-party libraries, as they appear in the code for the examples pages.
The MetricsGraphics.js code is shared under the terms of the Mozilla Public License v2.0. See the LICENSE
file at the root of the repository. The current logo is courtesy of Font Awesome.