@nickrsan/shp-write

0.3.7 • Public • Published

shp-write

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

This fork has been modified from the original mapbox version and uses the fixes for various geometries and zipfile downloads in https://github.com/hwbllmnn/shp-write - see Pull Requests Contained in this Branch below for more details

I have further made minor readme updates and packaged this for NPM so it is available immediately as a browserified package, see below.

Usage

For node.js or browserify

npm install --save @nickrsan/shp-write

Or in a browser

https://unpkg.com/@nickrsan/shp-write@latest/shpwrite.js

Testing

To test the download functionality run npm run make-test and open index.html in browser. This should start an immediate download of test features defined in indexTest.js.

Caveats

  • Requires a capable fancy modern browser with Typed Arrays support
  • Geometries: Point, LineString, Polygon, MultiLineString, MultiPolygon
  • Tabular-style properties export with Shapefile's field name length limit

Example

var shpwrite = require('shp-write');

// (optional) set names for zip file, zipped folder and feature types
var options = {
    file: 'zipfilename',
    folder: 'myshapes',
    types: {
        point: 'points_shapefilename',
        polygon: 'polygon_shapefilename',
        polyline: 'lines_shapefilename'
    }
}
// a GeoJSON bridge for features
shpwrite.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)

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 shapfile and call the callback with err and an object with

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

zip(geojson)

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

Other Implementations

Reference

Contributors

Pull requests contained in this branch

This branch includes the following PRs of the official repository:

Readme

Keywords

Package Sidebar

Install

npm i @nickrsan/shp-write

Weekly Downloads

73

Version

0.3.7

License

BSD-2-Clause

Unpacked Size

199 kB

Total Files

15

Last publish

Collaborators

  • nickrsan