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 🙏

© 2024 – Pkg Stats / Ryan Hefner

bar-provider

v2.0.2

Published

Easy configuration for LemonBoy's bar

Downloads

15

Readme

bar-provider

Build Status

This module provides a way to easily define data to be piped into LemonBoy's bar. It depends on generators, so run node with the --harmony flag (or use io.js).

Quickstart

bar.js

var Bar = require('bar-provider');
var bar = new Bar();

bar
	.button('dmenu_run', 'Menu')
	.center(function *() {
		return new Date();
	})
	.interval(1000);

Now you can pipe it to bar

$ node --harmony bar.js | bar

API

This module provides a chainable api to allow easy construction of a bar layout. Whenever any data should be provided to a method, you may pass a string or a generator function returning a string. Any generator function will be run through co and its return value will be rendered.

Adding data

bar.raw(data)

Simply append raw text

bar.left(data)

Prefixes with %{l}

bar.right(data)

Prefixes with %{r}

bar.center(data)

Prefixes with %{c}

bar.color(color, data)

Prefixes with %{F<color>} and postfixes with %{F}

bar.bg(color, data)

Prefixes with %{B<color>} and postfixes with %{B}

bar.button(cmd, data)

Prefixes %{A:<cmd>:} and postfixes with %{A}

Chaining

You may chain all the provided methods. If you omit the data argument, all the chained styles apply at once. So the following will give you blue background AND white text:

bar.bg('blue').color('white', 'Some Data');

while the following will print text on blue background followed by white text:

bar.bg('blue', 'Some Data').color('white', 'Some more Data')

Rendering

bar.render()

Generator function which, when run through co outputs a single line on the console.

bar.renderCo()

bar.render() wrapped via co. This returns immediately.

bar.interval(ms)

Normal function, which calls the render function at each interval.

Custom Styling

To allow styling of data returned from generator functions (think color for battery percentage), each generator function is passed a utility object, containing all the above methods. Simply return the result of a yielded method if neccessary. These may be chained as well

function *getBattery(utils) {
	//somehow get your battery percentage
	var percent = yield getPercentage();
	var color = percent > 50 ? 'green' : 'red';

	return yield utils.color(color, percent);
}

bar.right(getBattery);