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 🙏

© 2026 – Pkg Stats / Ryan Hefner

less-toolkit

v1.0.1

Published

Node.JS developer utilities for working with LESS files.

Downloads

15

Readme

less-toolkit

This is a bundle of Node.JS developer utilities for working with LESS files.

The utilities included:

CLI

A simple command-line interface for processing less files. It can take a file or path and output CSS in a target directory. The options for compilation are read from a configuration file.

Usage:

$ node cli /path/to/input.less /path/to/output.css options.js

The inputs and outputs can be any the following variations:

inputfile.LESS -> outputfile.CSS
inputfile.LESS -> /output/path
/input/path -> /output/path

The optional fourth argument specifies an options file (for example, development)

Options:

  • "debug": Enables debugging output
  • "force": Forces overwrite of any existing CSS files
  • "less" : An object passed directly to the less Parser.

Source documentation

File Watcher

A simple file watching daemon.

Usage:

$ node watcher /input/path /output/path /includes:/includes/subdir options.js &

The inputs and outputs can be any the following variations:

inputfile.LESS -> outputfile.CSS
inputfile.LESS -> /output/path
/input/path -> /output/path

The optional third argument is a colon-delimited list of other directories to watch (typically for LESS includes)

The optional fourth argument specifies an options file (for example, development)

Options:

  • "watcher_match_pattern": filter for file names
  • "debug": Enables debugging output
  • "force": Forces overwrite of any existing CSS files
  • "less" : An object passed directly to the less Parser.

Source documentation

Middleware

A simple Express-compatible middleware.

Usage:

...
app.use(require("less-toolkit").middleware({ "less": { "compress": true } }));
...

Options:

  • "debug": Enables debugging output
  • "force": Forces overwrite of any existing CSS files
  • "less" : An object passed directly to the less Parser.
  • "middleware_match": a function that returns true if the given URL should be handled by the middleware
    function(raw_url) {
        return /\.css$/.test(url.parse(raw_url).pathname);
    }
  • "middleware_map": a function that defines pairs of input / output for the given URL
    function(raw_url, pathname) { 
        return { 
            "input": path.join(__dirname, pathname).replace(/\.css$/, ".less"), 
            "output":  path.join(__dirname, pathname)
        }
    }

Source documentation

Processor library

A simple wrapper around the core Less parser. It takes an input, output, compilation options, and callback function. This library is re-used by the CLI, File Watcher, and Middleware.

Source documentation

License

MIT