Package Exports
- @mapbox/shp-write
- @mapbox/shp-write/dist/index.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@mapbox/shp-write) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
shp-write
ANNOUNCEMENT!
The npm package location (and subsequently unpkg url) for this repo has changed!
tl;dr: shp-write -> @mapbox/shp-write
Writes shapefile in pure javascript. Uses dbf for the data component, and jsZIP to generate ZIP file downloads in-browser.
Usage
For npm
npm install --save @mapbox/shp-writeYarn
yarn add @mapbox/shp-writeOr in a browser
https://unpkg.com/@mapbox/shp-write@latest/shpwrite.jsCaveats
- 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
- Uses jsZip for ZIP files, but compression is buggy so it uses STORE instead of DEFLATE.
Minimal Example
var shpwrite = require("@mapbox/shp-write");
// a GeoJSON bridge for features
const zipData = shpwrite.zip(
{
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 Example
var shpwrite = require("@mapbox/shp-write");
const options = {
folder: "my_internal_shapes_folder",
filename: "my_zip_filename",
outputType: "blob",
compression: "DEFLATE",
types: {
point: "mypoints",
polygon: "mypolygons",
polyline: "mylines",
},
};
// a GeoJSON bridge for features
const zipData = shpwrite.zip(
{
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
);Custom .prj file
To pass a custom WKT string in the .prj file to define a different projection the prj option can be used:
var options = {
prj: 'PROJCS["Amersfoort / RD New",GEOGCS["Amersfoort",DATUM["D_Amersfoort",SPHEROID["Bessel_1841",6377397.155,299.1528128]],PRIMEM["Greenwich",0],UNIT["Degree",0.017453292519943295]],PROJECTION["Stereographic_North_Pole"],PARAMETER["standard_parallel_1",52.15616055555555],PARAMETER["central_meridian",5.38763888888889],PARAMETER["scale_factor",0.9999079],PARAMETER["false_easting",155000],PARAMETER["false_northing",463000],UNIT["Meter",1]]'
}API
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, [options])
Generate a ArrayBuffer of a zipped shapefile, dbf, and prj, from a GeoJSON object.
DEPRECTEAD! May be removed in a future version
download(geojson, [options])
Given a GeoJSON FeatureCollection as an object, converts convertible features into Shapefiles and triggers a download.
The additional options parameter is passed to the underlying zip call.
This is now marked as deprecated because it applies to browsers only and the
user should instead rely on an external library for this functionality like
file-saver or downloadjs
Other Implementations
Reference
Contributors
- Nick Baugh niftylettuce@gmail.com