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

@crmackey/shp-write

v0.4.5

Published

write shapefiles from pure javascript

Downloads

610

Readme

shp-write

This repository is based on a fork from the original repo that has been updated to work better as an esm module and includes typings.

Writes shapefile in pure javascript. Uses dbf for the data component, and fflate to generate ZIP file downloads in-browser.

Installing

npm install --save @crmackey/shp-write

Caveats

  • Requires a modern browser with Typed Arrays support
  • Supported Geojson Geometries: Point, LineString, MultiLineString, MultiPoint, Polygon
  • Unsupported Geojson Geometries: MultiPolygon
  • Tabular-style properties export with Shapefile's field name length limit
  • Uses fflate for zip DEFLATE compression.

Example

import { download } from '@crmackey/shp-write'

// (optional) set names for feature types and zipped folder
var options = {
    /** zip file name, id you only pass this
    * the shapefile will also receive this name
    */
    name: 'ZippedShapefile',
    /** optional nested folder */
    folder: 'myshapes',
    /** optional explicit names for shapefiles generated 
    * for each type of geometry (applicable when mixed geometries are present)
    */
    types: {
        point: 'mypoints',
        polygon: 'mypolygons',
        line: 'mylines'
    }
}
// a GeoJSON bridge for features
download({
    type: 'FeatureCollection',
    features: [
        {
            type: 'Feature',
            geometry: {
                type: 'Point',
                coordinates: [0, 0]
            },
            properties: {
                name: 'Foo'
            }
        },
        {
            type: 'Feature',
            geometry: {
                type: 'Point',
                coordinates: [0, 10]
            },
            properties: {
                name: 'Bar'
            }
        }
    ]
}, options);
// triggers a download of a zip file with shapefiles contained within.

API

download(geojson, options)

Given a GeoJSON FeatureCollection as an object, converts convertible features into Shapefiles and triggers a download.

write(data, geometrytype, geometries, callback)

Given data, an array of objects for each row of data, geometry, the OGC standard geometry type (like POINT), geometries, a list of geometries as bare coordinate arrays, generate a shapefile and call the callback with err and an object with

{
    shp: DataView(),
    shx: DataView(),
    dbf: DataView()
}

zip(geojson, options)

Generate an Blob of a zipped shapefile, dbf, and prj, from a GeoJSON object.

zip and download options

These are the available options that can be passed into the zip and download functions:

interface WriterOptions {
  /** the zipfile name for the contained shapefile */
  name?: string;
  /** the names of the shapefile for each geometry type */
  types?: {
    /** the name for the point features shapefile if applicable */
    point: string;
    /** the name for the polygon features shapefile if applicable */
    polygon: string;
    /** the name for the line features shapefile if applicable */
    line: string;
};
  /** optional subfolder within zipfile that will contain the shapefile(s) */
  folder?: string;
}

Testing

Write

Run node ./example/write/write.js to generate shp, shx, dbf, files of every geometry type.

Run node ./example/write/linestring.js to generate shp, shx, dbf, files for a linestring.

Zip

Run node ./example/zip/zip.js to generate example zips of every geometry type.

Run node ./example/zip/linestring.js to generate a zip for a linestring.

Test geojson files

The files are named with the following format. ${geojson geometry type}-${dimensionality}-${single or multiple features in feature collection?}

The idea here is to provide a comprehensive list of geojson featureCollections that are supported

Other Implementations

  • https://code.google.com/p/pyshp/

Reference

  • http://www.esri.com/library/whitepapers/pdfs/shapefile.pdf

Contributors