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

@prantlf/zip-dir

v1.1.0

Published

Zips up a directory and saves the zip archive to disk or returns as a buffer.

Readme

@prantlf/zip-dir

NPM version Build Status codecov Dependency Status devDependency Status

Zips up a directory and saves the zip archive to disk or returns as a buffer.

This fork enhances the original project with the following functionality:

  • Depends on the most recent versions of jszip and other packages.
  • Supports both callback and Promise to notify about the finished work.
  • Offers extra parameters rootPath, comment, compressionLevel, omitEmptyDirs and allowEmptyRoot.

install

$ npm install @prantlf/zip-dir

example

var zipdir = require('@prantlf/zip-dir');

// `buffer` is the buffer of the zipped file
var buffer = await zipdir('/path/to/be/zipped');

zipdir('/path/to/be/zipped', function (err, buffer) {
  // `buffer` is the buffer of the zipped file
});

zipdir('/path/to/be/zipped', { rootPath: 'archived' }, function (err, buffer) {
  // Files and folders from `/path/to/be/zipped will`
  // be stored in `archived/` in the output zip file.
});

zipdir('/path/to/be/zipped', { saveTo: '~/myzip.zip' }, function (err, buffer) {
  // `buffer` is the buffer of the zipped file
  // And the buffer was saved to `~/myzip.zip`
});

// Use a filter option to prevent zipping other zip files!
// Keep in mind you have to allow a directory to descend into!
zipdir('/path/to/be/zipped', { filter: (path, stat) => !/\.zip$/.test(path) }, function (err, buffer) {
  
});

// Use an `each` option to call a function everytime a file is added, and receives the path
zipdir('/path/to/be/zipped', { each: path => console.log(p, "added!"), function (err, buffer) {

});
  

methods

var zipdir = require('@prantlf/zip-dir');

zipdir(dirPath, [options], [callback]) : [Promise]

Zips up dirPath recursively preserving directory structure and returns the compressed buffer on success. If the callback function is supplied, it will be called with (error, buffer) once the zipdir function is done. If not, the buffer or an error can be obtained from the returned promise. The callback and the promise are mutually exclusive. If options defined with a saveTo path, then the callback and promise will be delayed until the buffer has also been saved to disk.

Options

  • rootPath Folder path to create in the root of the zip file and place the input files and folder below it. Input files and folders will be placed directly to the zip file root by default.
  • saveTo A path to save the buffer to.
  • filter A function that is called for all items to determine whether or not they should be added to the zip buffer. Function is called with the fullPath and a stats object (fs.Stats). Return true to add the item; false otherwise. To include files within directories, directories must also pass this filter.
  • each A function that is called everytime a file or directory is added to the zip.
  • comment A comment to be stored to the zip file.
  • compressionLevel The level of compression to use. A number from 1 (best speed) and 9 (best compression). 6 is the default.
  • omitEmptyDirs Prevents empty directories from being included in the zip file. If the root folder to pack is empty, the whole operation will fail.
  • allowEmptyRoot Lets the empty root directory be included in the zip file, if theomitEmptyDirs is set to true.

license

MIT