@loaders.gl/shapefile 4.0.0-alpha.21 → 4.0.0-alpha.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -326,7 +326,7 @@
326
326
  }
327
327
 
328
328
  // src/dbf-loader.ts
329
- var VERSION = true ? "4.0.0-alpha.21" : "latest";
329
+ var VERSION = true ? "4.0.0-alpha.23" : "latest";
330
330
  var DBFWorkerLoader = {
331
331
  name: "DBF",
332
332
  id: "dbf",
@@ -475,7 +475,7 @@
475
475
  options,
476
476
  context: {
477
477
  ...context,
478
- parse: parseOnMainThread
478
+ _parse: parseOnMainThread
479
479
  }
480
480
  });
481
481
  WorkerBody.postMessage("done", { result });
@@ -488,7 +488,7 @@
488
488
  }
489
489
  };
490
490
  }
491
- function parseOnMainThread(arrayBuffer, options) {
491
+ function parseOnMainThread(arrayBuffer, loader, options, context) {
492
492
  return new Promise((resolve, reject) => {
493
493
  const id = requestId++;
494
494
  const onMessage = (type, payload2) => {
@@ -512,7 +512,12 @@
512
512
  WorkerBody.postMessage("process", payload);
513
513
  });
514
514
  }
515
- async function parseData({ loader, arrayBuffer, options, context }) {
515
+ async function parseData({
516
+ loader,
517
+ arrayBuffer,
518
+ options,
519
+ context
520
+ }) {
516
521
  let data;
517
522
  let parser;
518
523
  if (loader.parseSync || loader.parse) {
package/dist/dist.min.js CHANGED
@@ -498,6 +498,21 @@
498
498
  }
499
499
  });
500
500
 
501
+ // ../loader-utils/src/loader-types.ts
502
+ async function parseFromContext(data, loaders, options, context) {
503
+ return context._parse(data, loaders, options, context);
504
+ }
505
+ async function parseInBatchesFromContext(data, loader, options, context) {
506
+ if (!context._parseInBatches) {
507
+ throw new Error("parseInBatches");
508
+ }
509
+ return context._parseInBatches(data, loader, options, context);
510
+ }
511
+ var init_loader_types = __esm({
512
+ "../loader-utils/src/loader-types.ts"() {
513
+ }
514
+ });
515
+
501
516
  // ../../node_modules/@babel/runtime/helpers/esm/typeof.js
502
517
  function _typeof(obj) {
503
518
  "@babel/helpers - typeof";
@@ -564,6 +579,13 @@
564
579
  }
565
580
  });
566
581
 
582
+ // ../loader-utils/src/index.ts
583
+ var init_src = __esm({
584
+ "../loader-utils/src/index.ts"() {
585
+ init_loader_types();
586
+ }
587
+ });
588
+
567
589
  // ../gis/src/lib/binary-to-geojson.ts
568
590
  function binaryToGeometry(data, startIndex, endIndex) {
569
591
  switch (data.type) {
@@ -660,7 +682,7 @@
660
682
  });
661
683
  }
662
684
  function isCoord(array) {
663
- return Number.isFinite(array[0]) && Number.isFinite(array[1]);
685
+ return Array.isArray(array) && Number.isFinite(array[0]) && Number.isFinite(array[1]);
664
686
  }
665
687
  var init_transform = __esm({
666
688
  "../gis/src/lib/transform.ts"() {
@@ -668,7 +690,7 @@
668
690
  });
669
691
 
670
692
  // ../gis/src/index.ts
671
- var init_src = __esm({
693
+ var init_src2 = __esm({
672
694
  "../gis/src/index.ts"() {
673
695
  init_binary_to_geojson();
674
696
  init_transform();
@@ -6982,14 +7004,14 @@
6982
7004
  async function* parseShapefileInBatches(asyncIterator, options, context) {
6983
7005
  const { reproject = false, _targetCrs = "WGS84" } = options?.gis || {};
6984
7006
  const { shx, cpg, prj } = await loadShapefileSidecarFiles(options, context);
6985
- const shapeIterable = await context.parseInBatches(asyncIterator, SHPLoader, options);
7007
+ const shapeIterable = await parseInBatchesFromContext(asyncIterator, SHPLoader, options, context);
6986
7008
  let propertyIterable;
6987
- const dbfResponse = await context.fetch(replaceExtension(context?.url || "", "dbf"));
6988
- if (dbfResponse.ok) {
6989
- propertyIterable = await context.parseInBatches(dbfResponse, DBFLoader, {
7009
+ const dbfResponse = await context?.fetch(replaceExtension(context?.url || "", "dbf"));
7010
+ if (dbfResponse?.ok) {
7011
+ propertyIterable = await parseInBatchesFromContext(dbfResponse, DBFLoader, {
6990
7012
  ...options,
6991
7013
  dbf: { encoding: cpg || "latin1" }
6992
- });
7014
+ }, context);
6993
7015
  }
6994
7016
  let shapeHeader = (await shapeIterable.next()).value;
6995
7017
  if (shapeHeader && shapeHeader.batchType === "metadata") {
@@ -7033,12 +7055,12 @@
7033
7055
  async function parseShapefile(arrayBuffer, options, context) {
7034
7056
  const { reproject = false, _targetCrs = "WGS84" } = options?.gis || {};
7035
7057
  const { shx, cpg, prj } = await loadShapefileSidecarFiles(options, context);
7036
- const { header, geometries } = await context.parse(arrayBuffer, SHPLoader, options);
7058
+ const { header, geometries } = await parseFromContext(arrayBuffer, SHPLoader, options, context);
7037
7059
  const geojsonGeometries = parseGeometries(geometries);
7038
7060
  let properties = [];
7039
- const dbfResponse = await context.fetch(replaceExtension(context.url, "dbf"));
7040
- if (dbfResponse.ok) {
7041
- properties = await context.parse(dbfResponse, DBFLoader, { dbf: { encoding: cpg || "latin1" } });
7061
+ const dbfResponse = await context?.fetch(replaceExtension(context?.url, "dbf"));
7062
+ if (dbfResponse?.ok) {
7063
+ properties = await parseFromContext(dbfResponse, DBFLoader, { dbf: { encoding: cpg || "latin1" } }, context);
7042
7064
  }
7043
7065
  let features = joinProperties(geojsonGeometries, properties);
7044
7066
  if (reproject) {
@@ -7133,6 +7155,7 @@
7133
7155
  var init_parse_shapefile = __esm({
7134
7156
  "src/lib/parsers/parse-shapefile.ts"() {
7135
7157
  init_src();
7158
+ init_src2();
7136
7159
  init_esm();
7137
7160
  init_parse_shx();
7138
7161
  init_zip_batch_iterators();
@@ -7178,7 +7201,7 @@
7178
7201
  SHPWorkerLoader: () => SHPWorkerLoader,
7179
7202
  ShapefileLoader: () => ShapefileLoader
7180
7203
  });
7181
- var init_src2 = __esm({
7204
+ var init_src3 = __esm({
7182
7205
  "src/index.ts"() {
7183
7206
  init_shapefile_loader();
7184
7207
  init_dbf_loader();
@@ -7189,7 +7212,7 @@
7189
7212
  // src/bundle.ts
7190
7213
  var require_bundle = __commonJS({
7191
7214
  "src/bundle.ts"(exports4, module) {
7192
- var moduleExports = (init_src2(), src_exports);
7215
+ var moduleExports = (init_src3(), src_exports);
7193
7216
  globalThis.loaders = globalThis.loaders || {};
7194
7217
  module.exports = Object.assign(globalThis.loaders, moduleExports);
7195
7218
  }
@@ -11,7 +11,7 @@ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/de
11
11
  var _parseDbf = require("./lib/parsers/parse-dbf");
12
12
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
13
13
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
14
- var VERSION = typeof "4.0.0-alpha.21" !== 'undefined' ? "4.0.0-alpha.21" : 'latest';
14
+ var VERSION = typeof "4.0.0-alpha.23" !== 'undefined' ? "4.0.0-alpha.23" : 'latest';
15
15
  var DBFWorkerLoader = {
16
16
  name: 'DBF',
17
17
  id: 'dbf',
@@ -14,6 +14,7 @@ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/sli
14
14
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
15
15
  var _awaitAsyncGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/awaitAsyncGenerator"));
16
16
  var _wrapAsyncGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/wrapAsyncGenerator"));
17
+ var _loaderUtils = require("@loaders.gl/loader-utils");
17
18
  var _gis = require("@loaders.gl/gis");
18
19
  var _proj = require("@math.gl/proj4");
19
20
  var _parseShx = require("./parse-shx");
@@ -45,23 +46,23 @@ function _parseShapefileInBatches() {
45
46
  cpg = _yield$_awaitAsyncGen.cpg;
46
47
  prj = _yield$_awaitAsyncGen.prj;
47
48
  _context.next = 9;
48
- return (0, _awaitAsyncGenerator2.default)(context.parseInBatches(asyncIterator, _shpLoader.SHPLoader, options));
49
+ return (0, _awaitAsyncGenerator2.default)((0, _loaderUtils.parseInBatchesFromContext)(asyncIterator, _shpLoader.SHPLoader, options, context));
49
50
  case 9:
50
51
  shapeIterable = _context.sent;
51
52
  _context.next = 12;
52
- return (0, _awaitAsyncGenerator2.default)(context.fetch(replaceExtension((context === null || context === void 0 ? void 0 : context.url) || '', 'dbf')));
53
+ return (0, _awaitAsyncGenerator2.default)(context === null || context === void 0 ? void 0 : context.fetch(replaceExtension((context === null || context === void 0 ? void 0 : context.url) || '', 'dbf')));
53
54
  case 12:
54
55
  dbfResponse = _context.sent;
55
- if (!dbfResponse.ok) {
56
+ if (!(dbfResponse !== null && dbfResponse !== void 0 && dbfResponse.ok)) {
56
57
  _context.next = 17;
57
58
  break;
58
59
  }
59
60
  _context.next = 16;
60
- return (0, _awaitAsyncGenerator2.default)(context.parseInBatches(dbfResponse, _dbfLoader.DBFLoader, _objectSpread(_objectSpread({}, options), {}, {
61
+ return (0, _awaitAsyncGenerator2.default)((0, _loaderUtils.parseInBatchesFromContext)(dbfResponse, _dbfLoader.DBFLoader, _objectSpread(_objectSpread({}, options), {}, {
61
62
  dbf: {
62
63
  encoding: cpg || 'latin1'
63
64
  }
64
- })));
65
+ }), context));
65
66
  case 16:
66
67
  propertyIterable = _context.sent;
67
68
  case 17:
@@ -181,7 +182,7 @@ function parseShapefile(_x4, _x5, _x6) {
181
182
  }
182
183
  function _parseShapefile() {
183
184
  _parseShapefile = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(arrayBuffer, options, context) {
184
- var _ref2, _ref2$reproject, reproject, _ref2$_targetCrs, _targetCrs, _yield$loadShapefileS, shx, cpg, prj, _yield$context$parse, header, geometries, geojsonGeometries, properties, dbfResponse, features;
185
+ var _ref2, _ref2$reproject, reproject, _ref2$_targetCrs, _targetCrs, _yield$loadShapefileS, shx, cpg, prj, _yield$parseFromConte, header, geometries, geojsonGeometries, properties, dbfResponse, features;
185
186
  return _regenerator.default.wrap(function _callee2$(_context2) {
186
187
  while (1) switch (_context2.prev = _context2.next) {
187
188
  case 0:
@@ -194,27 +195,27 @@ function _parseShapefile() {
194
195
  cpg = _yield$loadShapefileS.cpg;
195
196
  prj = _yield$loadShapefileS.prj;
196
197
  _context2.next = 9;
197
- return context.parse(arrayBuffer, _shpLoader.SHPLoader, options);
198
+ return (0, _loaderUtils.parseFromContext)(arrayBuffer, _shpLoader.SHPLoader, options, context);
198
199
  case 9:
199
- _yield$context$parse = _context2.sent;
200
- header = _yield$context$parse.header;
201
- geometries = _yield$context$parse.geometries;
200
+ _yield$parseFromConte = _context2.sent;
201
+ header = _yield$parseFromConte.header;
202
+ geometries = _yield$parseFromConte.geometries;
202
203
  geojsonGeometries = parseGeometries(geometries);
203
204
  properties = [];
204
205
  _context2.next = 16;
205
- return context.fetch(replaceExtension(context.url, 'dbf'));
206
+ return context === null || context === void 0 ? void 0 : context.fetch(replaceExtension(context === null || context === void 0 ? void 0 : context.url, 'dbf'));
206
207
  case 16:
207
208
  dbfResponse = _context2.sent;
208
- if (!dbfResponse.ok) {
209
+ if (!(dbfResponse !== null && dbfResponse !== void 0 && dbfResponse.ok)) {
209
210
  _context2.next = 21;
210
211
  break;
211
212
  }
212
213
  _context2.next = 20;
213
- return context.parse(dbfResponse, _dbfLoader.DBFLoader, {
214
+ return (0, _loaderUtils.parseFromContext)(dbfResponse, _dbfLoader.DBFLoader, {
214
215
  dbf: {
215
216
  encoding: cpg || 'latin1'
216
217
  }
217
- });
218
+ }, context);
218
219
  case 20:
219
220
  properties = _context2.sent;
220
221
  case 21:
@@ -1 +1 @@
1
- {"version":3,"file":"parse-shapefile.js","names":["_gis","require","_proj","_parseShx","_zipBatchIterators","_shpLoader","_dbfLoader","_createForOfIteratorHelper","o","allowArrayLike","it","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","i","F","s","n","done","value","e","_e","f","TypeError","normalCompletion","didErr","err","call","step","next","_e2","return","minLen","_arrayLikeToArray","Object","prototype","toString","slice","constructor","name","from","test","arr","len","arr2","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","arguments","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","_asyncIterator","iterable","method","async","sync","retry","asyncIterator","AsyncFromSyncIterator","AsyncFromSyncIteratorContinuation","r","Promise","reject","resolve","then","_return","ret","throw","_throw","thr","parseShapefileInBatches","_x","_x2","_x3","_parseShapefileInBatches","_wrapAsyncGenerator2","_regenerator","mark","_callee","options","context","_ref","_ref$reproject","reproject","_ref$_targetCrs","_targetCrs","_yield$_awaitAsyncGen","shx","cpg","prj","shapeIterable","propertyIterable","dbfResponse","shapeHeader","dbfHeader","_iteratorAbruptCompletion","_didIteratorError","_iteratorError","_iterator","_step","item","geometries","properties","_item","geojsonGeometries","features","wrap","_callee$","_context","prev","gis","_awaitAsyncGenerator2","loadShapefileSidecarFiles","sent","parseInBatches","SHPLoader","fetch","replaceExtension","url","ok","DBFLoader","dbf","encoding","batchType","zipBatchIterators","_slicedToArray2","parseGeometries","joinProperties","reprojectFeatures","header","data","t0","finish","stop","parseShapefile","_x4","_x5","_x6","_parseShapefile","_asyncToGenerator2","_callee2","arrayBuffer","_ref2","_ref2$reproject","_ref2$_targetCrs","_yield$loadShapefileS","_yield$context$parse","_callee2$","_context2","parse","abrupt","_iterator2","_step2","geom","binaryToGeometry","geometry","feature","type","sourceCrs","targetCrs","projection","Proj4Projection","to","transformGeoJsonCoords","coord","project","_x7","_x8","_loadShapefileSidecarFiles","_callee3","shxPromise","cpgPromise","prjPromise","shxResponse","cpgResponse","prjResponse","_callee3$","_context3","all","parseShx","text","newExtension","baseName","basename","extension","extname","isUpperCase","toUpperCase","concat","extIndex","lastIndexOf","substr"],"sources":["../../../../src/lib/parsers/parse-shapefile.ts"],"sourcesContent":["// import type {Feature} from '@loaders.gl/gis';\nimport type {SHXOutput} from './parse-shx';\nimport type {SHPHeader} from './parse-shp-header';\nimport type {LoaderContext} from '@loaders.gl/loader-utils';\nimport type {ShapefileLoaderOptions} from './types';\n\nimport {binaryToGeometry, transformGeoJsonCoords} from '@loaders.gl/gis';\nimport {Proj4Projection} from '@math.gl/proj4';\nimport {parseShx} from './parse-shx';\nimport {zipBatchIterators} from '../streaming/zip-batch-iterators';\nimport {SHPLoader} from '../../shp-loader';\nimport {DBFLoader} from '../../dbf-loader';\n\ntype Feature = any;\ninterface ShapefileOutput {\n encoding?: string;\n prj?: string;\n shx?: SHXOutput;\n header: SHPHeader;\n data: object[];\n}\n/**\n * Parsing of file in batches\n */\n// eslint-disable-next-line max-statements, complexity\nexport async function* parseShapefileInBatches(\n asyncIterator: AsyncIterable<ArrayBuffer> | Iterable<ArrayBuffer>,\n options?: ShapefileLoaderOptions,\n context?: LoaderContext\n): AsyncIterable<ShapefileOutput> {\n const {reproject = false, _targetCrs = 'WGS84'} = options?.gis || {};\n const {shx, cpg, prj} = await loadShapefileSidecarFiles(options, context);\n\n // parse geometries\n // @ts-ignore context must be defined\n const shapeIterable: any = await context.parseInBatches(asyncIterator, SHPLoader, options);\n\n // parse properties\n let propertyIterable: any;\n // @ts-ignore context must be defined\n const dbfResponse = await context.fetch(replaceExtension(context?.url || '', 'dbf'));\n if (dbfResponse.ok) {\n // @ts-ignore context must be defined\n propertyIterable = await context.parseInBatches(dbfResponse, DBFLoader, {\n ...options,\n dbf: {encoding: cpg || 'latin1'}\n });\n }\n\n // When `options.metadata` is `true`, there's an extra initial `metadata`\n // object before the iterator starts. zipBatchIterators expects to receive\n // batches of Array objects, and will fail with non-iterable batches, so it's\n // important to skip over the first batch.\n let shapeHeader = (await shapeIterable.next()).value;\n if (shapeHeader && shapeHeader.batchType === 'metadata') {\n shapeHeader = (await shapeIterable.next()).value;\n }\n\n let dbfHeader: {batchType?: string} = {};\n if (propertyIterable) {\n dbfHeader = (await propertyIterable.next()).value;\n if (dbfHeader && dbfHeader.batchType === 'metadata') {\n dbfHeader = (await propertyIterable.next()).value;\n }\n }\n\n let iterator: any;\n if (propertyIterable) {\n iterator = zipBatchIterators(shapeIterable, propertyIterable);\n } else {\n iterator = shapeIterable;\n }\n\n for await (const item of iterator) {\n let geometries: any;\n let properties: any;\n if (!propertyIterable) {\n geometries = item;\n } else {\n [geometries, properties] = item;\n }\n\n const geojsonGeometries = parseGeometries(geometries);\n let features = joinProperties(geojsonGeometries, properties);\n if (reproject) {\n // @ts-ignore\n features = reprojectFeatures(features, prj, _targetCrs);\n }\n yield {\n encoding: cpg,\n prj,\n shx,\n header: shapeHeader,\n data: features\n };\n }\n}\n\n/**\n * Parse shapefile\n *\n * @param arrayBuffer\n * @param options\n * @param context\n * @returns output of shapefile\n */\nexport async function parseShapefile(\n arrayBuffer: ArrayBuffer,\n options?: ShapefileLoaderOptions,\n context?: LoaderContext\n): Promise<ShapefileOutput> {\n const {reproject = false, _targetCrs = 'WGS84'} = options?.gis || {};\n const {shx, cpg, prj} = await loadShapefileSidecarFiles(options, context);\n\n // parse geometries\n // @ts-ignore context must be defined\n const {header, geometries} = await context.parse(arrayBuffer, SHPLoader, options); // {shp: shx}\n\n const geojsonGeometries = parseGeometries(geometries);\n\n // parse properties\n let properties = [];\n\n // @ts-ignore context must be defined\n const dbfResponse = await context.fetch(replaceExtension(context.url, 'dbf'));\n if (dbfResponse.ok) {\n // @ts-ignore context must be defined\n properties = await context.parse(dbfResponse, DBFLoader, {dbf: {encoding: cpg || 'latin1'}});\n }\n\n let features = joinProperties(geojsonGeometries, properties);\n if (reproject) {\n features = reprojectFeatures(features, prj, _targetCrs);\n }\n\n return {\n encoding: cpg,\n prj,\n shx,\n header,\n data: features\n };\n}\n\n/**\n * Parse geometries\n *\n * @param geometries\n * @returns geometries as an array\n */\nfunction parseGeometries(geometries: any[]): any[] {\n const geojsonGeometries: any[] = [];\n for (const geom of geometries) {\n geojsonGeometries.push(binaryToGeometry(geom));\n }\n return geojsonGeometries;\n}\n\n/**\n * Join properties and geometries into features\n *\n * @param geometries [description]\n * @param properties [description]\n * @return [description]\n */\nfunction joinProperties(geometries: object[], properties: object[]): Feature[] {\n const features: Feature[] = [];\n for (let i = 0; i < geometries.length; i++) {\n const geometry = geometries[i];\n const feature: Feature = {\n type: 'Feature',\n geometry,\n // properties can be undefined if dbfResponse above was empty\n properties: (properties && properties[i]) || {}\n };\n features.push(feature);\n }\n\n return features;\n}\n\n/**\n * Reproject GeoJSON features to output CRS\n *\n * @param features parsed GeoJSON features\n * @param sourceCrs source coordinate reference system\n * @param targetCrs †arget coordinate reference system\n * @return Reprojected Features\n */\nfunction reprojectFeatures(features: Feature[], sourceCrs?: string, targetCrs?: string): Feature[] {\n if (!sourceCrs && !targetCrs) {\n return features;\n }\n\n const projection = new Proj4Projection({from: sourceCrs || 'WGS84', to: targetCrs || 'WGS84'});\n return transformGeoJsonCoords(features, (coord) => projection.project(coord));\n}\n\n/**\n *\n * @param options\n * @param context\n * @returns Promise\n */\n// eslint-disable-next-line max-statements\nexport async function loadShapefileSidecarFiles(\n options?: object,\n context?: LoaderContext\n): Promise<{\n shx?: SHXOutput;\n cpg?: string;\n prj?: string;\n}> {\n // Attempt a parallel load of the small sidecar files\n // @ts-ignore context must be defined\n const {url, fetch} = context;\n const shxPromise = fetch(replaceExtension(url, 'shx'));\n const cpgPromise = fetch(replaceExtension(url, 'cpg'));\n const prjPromise = fetch(replaceExtension(url, 'prj'));\n await Promise.all([shxPromise, cpgPromise, prjPromise]);\n\n let shx: SHXOutput | undefined;\n let cpg: string | undefined;\n let prj: string | undefined;\n\n const shxResponse = await shxPromise;\n if (shxResponse.ok) {\n const arrayBuffer = await shxResponse.arrayBuffer();\n shx = parseShx(arrayBuffer);\n }\n\n const cpgResponse = await cpgPromise;\n if (cpgResponse.ok) {\n cpg = await cpgResponse.text();\n }\n\n const prjResponse = await prjPromise;\n if (prjResponse.ok) {\n prj = await prjResponse.text();\n }\n\n return {\n shx,\n cpg,\n prj\n };\n}\n\n/**\n * Replace the extension at the end of a path.\n *\n * Matches the case of new extension with the case of the original file extension,\n * to increase the chance of finding files without firing off a request storm looking for various case combinations\n *\n * NOTE: Extensions can be both lower and uppercase\n * per spec, extensions should be lower case, but that doesn't mean they always are. See:\n * calvinmetcalf/shapefile-js#64, mapserver/mapserver#4712\n * https://trac.osgeo.org/mapserver/ticket/166\n */\nexport function replaceExtension(url: string, newExtension: string): string {\n const baseName = basename(url);\n const extension = extname(url);\n const isUpperCase = extension === extension.toUpperCase();\n if (isUpperCase) {\n newExtension = newExtension.toUpperCase();\n }\n return `${baseName}.${newExtension}`;\n}\n\n// NOTE - this gives the entire path minus extension (i.e. NOT same as path.basename)\n/**\n * @param url\n * @returns string\n */\nfunction basename(url: string): string {\n const extIndex = url && url.lastIndexOf('.');\n if (typeof extIndex === 'number') {\n return extIndex >= 0 ? url.substr(0, extIndex) : '';\n }\n return extIndex;\n}\n/**\n * @param url\n * @returns string\n */\nfunction extname(url: string): string {\n const extIndex = url && url.lastIndexOf('.');\n if (typeof extIndex === 'number') {\n return extIndex >= 0 ? url.substr(extIndex + 1) : '';\n }\n return extIndex;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"parse-shapefile.js","names":["_loaderUtils","require","_gis","_proj","_parseShx","_zipBatchIterators","_shpLoader","_dbfLoader","_createForOfIteratorHelper","o","allowArrayLike","it","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","i","F","s","n","done","value","e","_e","f","TypeError","normalCompletion","didErr","err","call","step","next","_e2","return","minLen","_arrayLikeToArray","Object","prototype","toString","slice","constructor","name","from","test","arr","len","arr2","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","arguments","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","_asyncIterator","iterable","method","async","sync","retry","asyncIterator","AsyncFromSyncIterator","AsyncFromSyncIteratorContinuation","r","Promise","reject","resolve","then","_return","ret","throw","_throw","thr","parseShapefileInBatches","_x","_x2","_x3","_parseShapefileInBatches","_wrapAsyncGenerator2","_regenerator","mark","_callee","options","context","_ref","_ref$reproject","reproject","_ref$_targetCrs","_targetCrs","_yield$_awaitAsyncGen","shx","cpg","prj","shapeIterable","propertyIterable","dbfResponse","shapeHeader","dbfHeader","_iteratorAbruptCompletion","_didIteratorError","_iteratorError","_iterator","_step","item","geometries","properties","_item","geojsonGeometries","features","wrap","_callee$","_context","prev","gis","_awaitAsyncGenerator2","loadShapefileSidecarFiles","sent","parseInBatchesFromContext","SHPLoader","fetch","replaceExtension","url","ok","DBFLoader","dbf","encoding","batchType","zipBatchIterators","_slicedToArray2","parseGeometries","joinProperties","reprojectFeatures","header","data","t0","finish","stop","parseShapefile","_x4","_x5","_x6","_parseShapefile","_asyncToGenerator2","_callee2","arrayBuffer","_ref2","_ref2$reproject","_ref2$_targetCrs","_yield$loadShapefileS","_yield$parseFromConte","_callee2$","_context2","parseFromContext","abrupt","_iterator2","_step2","geom","binaryToGeometry","geometry","feature","type","sourceCrs","targetCrs","projection","Proj4Projection","to","transformGeoJsonCoords","coord","project","_x7","_x8","_loadShapefileSidecarFiles","_callee3","shxPromise","cpgPromise","prjPromise","shxResponse","cpgResponse","prjResponse","_callee3$","_context3","all","parseShx","text","newExtension","baseName","basename","extension","extname","isUpperCase","toUpperCase","concat","extIndex","lastIndexOf","substr"],"sources":["../../../../src/lib/parsers/parse-shapefile.ts"],"sourcesContent":["// import type {Feature} from '@loaders.gl/gis';\nimport {LoaderContext, parseInBatchesFromContext, parseFromContext} from '@loaders.gl/loader-utils';\nimport {binaryToGeometry, transformGeoJsonCoords} from '@loaders.gl/gis';\nimport {Proj4Projection} from '@math.gl/proj4';\n\nimport type {SHXOutput} from './parse-shx';\nimport type {SHPHeader} from './parse-shp-header';\nimport type {ShapefileLoaderOptions} from './types';\nimport {parseShx} from './parse-shx';\nimport {zipBatchIterators} from '../streaming/zip-batch-iterators';\nimport {SHPLoader} from '../../shp-loader';\nimport {DBFLoader} from '../../dbf-loader';\n\ntype Feature = any;\ninterface ShapefileOutput {\n encoding?: string;\n prj?: string;\n shx?: SHXOutput;\n header: SHPHeader;\n data: object[];\n}\n/**\n * Parsing of file in batches\n */\n// eslint-disable-next-line max-statements, complexity\nexport async function* parseShapefileInBatches(\n asyncIterator: AsyncIterable<ArrayBuffer> | Iterable<ArrayBuffer>,\n options?: ShapefileLoaderOptions,\n context?: LoaderContext\n): AsyncIterable<ShapefileOutput> {\n const {reproject = false, _targetCrs = 'WGS84'} = options?.gis || {};\n const {shx, cpg, prj} = await loadShapefileSidecarFiles(options, context);\n\n // parse geometries\n const shapeIterable: any = await parseInBatchesFromContext(\n asyncIterator,\n SHPLoader,\n options,\n context!\n );\n\n // parse properties\n let propertyIterable: any;\n const dbfResponse = await context?.fetch(replaceExtension(context?.url || '', 'dbf'));\n if (dbfResponse?.ok) {\n propertyIterable = await parseInBatchesFromContext(\n dbfResponse as any,\n DBFLoader,\n {\n ...options,\n dbf: {encoding: cpg || 'latin1'}\n },\n context!\n );\n }\n\n // When `options.metadata` is `true`, there's an extra initial `metadata`\n // object before the iterator starts. zipBatchIterators expects to receive\n // batches of Array objects, and will fail with non-iterable batches, so it's\n // important to skip over the first batch.\n let shapeHeader = (await shapeIterable.next()).value;\n if (shapeHeader && shapeHeader.batchType === 'metadata') {\n shapeHeader = (await shapeIterable.next()).value;\n }\n\n let dbfHeader: {batchType?: string} = {};\n if (propertyIterable) {\n dbfHeader = (await propertyIterable.next()).value;\n if (dbfHeader && dbfHeader.batchType === 'metadata') {\n dbfHeader = (await propertyIterable.next()).value;\n }\n }\n\n let iterator: any;\n if (propertyIterable) {\n iterator = zipBatchIterators(shapeIterable, propertyIterable);\n } else {\n iterator = shapeIterable;\n }\n\n for await (const item of iterator) {\n let geometries: any;\n let properties: any;\n if (!propertyIterable) {\n geometries = item;\n } else {\n [geometries, properties] = item;\n }\n\n const geojsonGeometries = parseGeometries(geometries);\n let features = joinProperties(geojsonGeometries, properties);\n if (reproject) {\n // @ts-ignore\n features = reprojectFeatures(features, prj, _targetCrs);\n }\n yield {\n encoding: cpg,\n prj,\n shx,\n header: shapeHeader,\n data: features\n };\n }\n}\n\n/**\n * Parse shapefile\n *\n * @param arrayBuffer\n * @param options\n * @param context\n * @returns output of shapefile\n */\nexport async function parseShapefile(\n arrayBuffer: ArrayBuffer,\n options?: ShapefileLoaderOptions,\n context?: LoaderContext\n): Promise<ShapefileOutput> {\n const {reproject = false, _targetCrs = 'WGS84'} = options?.gis || {};\n const {shx, cpg, prj} = await loadShapefileSidecarFiles(options, context);\n\n // parse geometries\n const {header, geometries} = await parseFromContext(arrayBuffer, SHPLoader, options, context!); // {shp: shx}\n\n const geojsonGeometries = parseGeometries(geometries);\n\n // parse properties\n let properties = [];\n\n const dbfResponse = await context?.fetch(replaceExtension(context?.url!, 'dbf'));\n if (dbfResponse?.ok) {\n properties = await parseFromContext(\n dbfResponse as any,\n DBFLoader,\n {dbf: {encoding: cpg || 'latin1'}},\n context!\n );\n }\n\n let features = joinProperties(geojsonGeometries, properties);\n if (reproject) {\n features = reprojectFeatures(features, prj, _targetCrs);\n }\n\n return {\n encoding: cpg,\n prj,\n shx,\n header,\n data: features\n };\n}\n\n/**\n * Parse geometries\n *\n * @param geometries\n * @returns geometries as an array\n */\nfunction parseGeometries(geometries: any[]): any[] {\n const geojsonGeometries: any[] = [];\n for (const geom of geometries) {\n geojsonGeometries.push(binaryToGeometry(geom));\n }\n return geojsonGeometries;\n}\n\n/**\n * Join properties and geometries into features\n *\n * @param geometries [description]\n * @param properties [description]\n * @return [description]\n */\nfunction joinProperties(geometries: object[], properties: object[]): Feature[] {\n const features: Feature[] = [];\n for (let i = 0; i < geometries.length; i++) {\n const geometry = geometries[i];\n const feature: Feature = {\n type: 'Feature',\n geometry,\n // properties can be undefined if dbfResponse above was empty\n properties: (properties && properties[i]) || {}\n };\n features.push(feature);\n }\n\n return features;\n}\n\n/**\n * Reproject GeoJSON features to output CRS\n *\n * @param features parsed GeoJSON features\n * @param sourceCrs source coordinate reference system\n * @param targetCrs †arget coordinate reference system\n * @return Reprojected Features\n */\nfunction reprojectFeatures(features: Feature[], sourceCrs?: string, targetCrs?: string): Feature[] {\n if (!sourceCrs && !targetCrs) {\n return features;\n }\n\n const projection = new Proj4Projection({from: sourceCrs || 'WGS84', to: targetCrs || 'WGS84'});\n return transformGeoJsonCoords(features, (coord) => projection.project(coord));\n}\n\n/**\n *\n * @param options\n * @param context\n * @returns Promise\n */\n// eslint-disable-next-line max-statements\nexport async function loadShapefileSidecarFiles(\n options?: object,\n context?: LoaderContext\n): Promise<{\n shx?: SHXOutput;\n cpg?: string;\n prj?: string;\n}> {\n // Attempt a parallel load of the small sidecar files\n // @ts-ignore context must be defined\n const {url, fetch} = context;\n const shxPromise = fetch(replaceExtension(url, 'shx'));\n const cpgPromise = fetch(replaceExtension(url, 'cpg'));\n const prjPromise = fetch(replaceExtension(url, 'prj'));\n await Promise.all([shxPromise, cpgPromise, prjPromise]);\n\n let shx: SHXOutput | undefined;\n let cpg: string | undefined;\n let prj: string | undefined;\n\n const shxResponse = await shxPromise;\n if (shxResponse.ok) {\n const arrayBuffer = await shxResponse.arrayBuffer();\n shx = parseShx(arrayBuffer);\n }\n\n const cpgResponse = await cpgPromise;\n if (cpgResponse.ok) {\n cpg = await cpgResponse.text();\n }\n\n const prjResponse = await prjPromise;\n if (prjResponse.ok) {\n prj = await prjResponse.text();\n }\n\n return {\n shx,\n cpg,\n prj\n };\n}\n\n/**\n * Replace the extension at the end of a path.\n *\n * Matches the case of new extension with the case of the original file extension,\n * to increase the chance of finding files without firing off a request storm looking for various case combinations\n *\n * NOTE: Extensions can be both lower and uppercase\n * per spec, extensions should be lower case, but that doesn't mean they always are. See:\n * calvinmetcalf/shapefile-js#64, mapserver/mapserver#4712\n * https://trac.osgeo.org/mapserver/ticket/166\n */\nexport function replaceExtension(url: string, newExtension: string): string {\n const baseName = basename(url);\n const extension = extname(url);\n const isUpperCase = extension === extension.toUpperCase();\n if (isUpperCase) {\n newExtension = newExtension.toUpperCase();\n }\n return `${baseName}.${newExtension}`;\n}\n\n// NOTE - this gives the entire path minus extension (i.e. NOT same as path.basename)\n/**\n * @param url\n * @returns string\n */\nfunction basename(url: string): string {\n const extIndex = url && url.lastIndexOf('.');\n if (typeof extIndex === 'number') {\n return extIndex >= 0 ? url.substr(0, extIndex) : '';\n }\n return extIndex;\n}\n/**\n * @param url\n * @returns string\n */\nfunction extname(url: string): string {\n const extIndex = url && url.lastIndexOf('.');\n if (typeof extIndex === 'number') {\n return extIndex >= 0 ? url.substr(extIndex + 1) : '';\n }\n return extIndex;\n}\n"],"mappings":"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"}
@@ -3,10 +3,10 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports._typecheckShapefileLoader = exports.ShapefileLoader = void 0;
6
+ exports.ShapefileLoader = void 0;
7
7
  var _shpLoader = require("./shp-loader");
8
8
  var _parseShapefile = require("./lib/parsers/parse-shapefile");
9
- var VERSION = typeof "4.0.0-alpha.21" !== 'undefined' ? "4.0.0-alpha.21" : 'latest';
9
+ var VERSION = typeof "4.0.0-alpha.23" !== 'undefined' ? "4.0.0-alpha.23" : 'latest';
10
10
  var ShapefileLoader = {
11
11
  name: 'Shapefile',
12
12
  id: 'shapefile',
@@ -26,6 +26,4 @@ var ShapefileLoader = {
26
26
  parseInBatches: _parseShapefile.parseShapefileInBatches
27
27
  };
28
28
  exports.ShapefileLoader = ShapefileLoader;
29
- var _typecheckShapefileLoader = ShapefileLoader;
30
- exports._typecheckShapefileLoader = _typecheckShapefileLoader;
31
29
  //# sourceMappingURL=shapefile-loader.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"shapefile-loader.js","names":["_shpLoader","require","_parseShapefile","VERSION","ShapefileLoader","name","id","module","version","category","extensions","mimeTypes","tests","Uint8Array","SHP_MAGIC_NUMBER","buffer","options","shapefile","shp","_maxDimensions","parse","parseShapefile","parseInBatches","parseShapefileInBatches","exports","_typecheckShapefileLoader"],"sources":["../../src/shapefile-loader.ts"],"sourcesContent":["import type {LoaderWithParser} from '@loaders.gl/loader-utils';\nimport {SHP_MAGIC_NUMBER} from './shp-loader';\nimport {parseShapefile, parseShapefileInBatches} from './lib/parsers/parse-shapefile';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\n/**\n * Shapefile loader\n * @note Shapefile is multifile format and requires providing additional files\n */\nexport const ShapefileLoader = {\n name: 'Shapefile',\n id: 'shapefile',\n module: 'shapefile',\n version: VERSION,\n category: 'geometry',\n extensions: ['shp'],\n mimeTypes: ['application/octet-stream'],\n tests: [new Uint8Array(SHP_MAGIC_NUMBER).buffer],\n options: {\n shapefile: {},\n shp: {\n _maxDimensions: 4\n }\n },\n parse: parseShapefile,\n parseInBatches: parseShapefileInBatches\n};\n\nexport const _typecheckShapefileLoader: LoaderWithParser = ShapefileLoader;\n"],"mappings":";;;;;;AACA,IAAAA,UAAA,GAAAC,OAAA;AACA,IAAAC,eAAA,GAAAD,OAAA;AAIA,IAAME,OAAO,GAAG,uBAAkB,KAAK,WAAW,sBAAiB,QAAQ;AAMpE,IAAMC,eAAe,GAAG;EAC7BC,IAAI,EAAE,WAAW;EACjBC,EAAE,EAAE,WAAW;EACfC,MAAM,EAAE,WAAW;EACnBC,OAAO,EAAEL,OAAO;EAChBM,QAAQ,EAAE,UAAU;EACpBC,UAAU,EAAE,CAAC,KAAK,CAAC;EACnBC,SAAS,EAAE,CAAC,0BAA0B,CAAC;EACvCC,KAAK,EAAE,CAAC,IAAIC,UAAU,CAACC,2BAAgB,CAAC,CAACC,MAAM,CAAC;EAChDC,OAAO,EAAE;IACPC,SAAS,EAAE,CAAC,CAAC;IACbC,GAAG,EAAE;MACHC,cAAc,EAAE;IAClB;EACF,CAAC;EACDC,KAAK,EAAEC,8BAAc;EACrBC,cAAc,EAAEC;AAClB,CAAC;AAACC,OAAA,CAAApB,eAAA,GAAAA,eAAA;AAEK,IAAMqB,yBAA2C,GAAGrB,eAAe;AAACoB,OAAA,CAAAC,yBAAA,GAAAA,yBAAA"}
1
+ {"version":3,"file":"shapefile-loader.js","names":["_shpLoader","require","_parseShapefile","VERSION","ShapefileLoader","name","id","module","version","category","extensions","mimeTypes","tests","Uint8Array","SHP_MAGIC_NUMBER","buffer","options","shapefile","shp","_maxDimensions","parse","parseShapefile","parseInBatches","parseShapefileInBatches","exports"],"sources":["../../src/shapefile-loader.ts"],"sourcesContent":["import type {LoaderOptions, LoaderWithParser} from '@loaders.gl/loader-utils';\nimport {SHP_MAGIC_NUMBER} from './shp-loader';\nimport {parseShapefile, parseShapefileInBatches} from './lib/parsers/parse-shapefile';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\n/**\n * Shapefile loader\n * @note Shapefile is multifile format and requires providing additional files\n */\nexport const ShapefileLoader: LoaderWithParser<any, any, LoaderOptions> = {\n name: 'Shapefile',\n id: 'shapefile',\n module: 'shapefile',\n version: VERSION,\n category: 'geometry',\n extensions: ['shp'],\n mimeTypes: ['application/octet-stream'],\n tests: [new Uint8Array(SHP_MAGIC_NUMBER).buffer],\n options: {\n shapefile: {},\n shp: {\n _maxDimensions: 4\n }\n },\n parse: parseShapefile,\n parseInBatches: parseShapefileInBatches\n};\n"],"mappings":";;;;;;AACA,IAAAA,UAAA,GAAAC,OAAA;AACA,IAAAC,eAAA,GAAAD,OAAA;AAIA,IAAME,OAAO,GAAG,uBAAkB,KAAK,WAAW,sBAAiB,QAAQ;AAMpE,IAAMC,eAA0D,GAAG;EACxEC,IAAI,EAAE,WAAW;EACjBC,EAAE,EAAE,WAAW;EACfC,MAAM,EAAE,WAAW;EACnBC,OAAO,EAAEL,OAAO;EAChBM,QAAQ,EAAE,UAAU;EACpBC,UAAU,EAAE,CAAC,KAAK,CAAC;EACnBC,SAAS,EAAE,CAAC,0BAA0B,CAAC;EACvCC,KAAK,EAAE,CAAC,IAAIC,UAAU,CAACC,2BAAgB,CAAC,CAACC,MAAM,CAAC;EAChDC,OAAO,EAAE;IACPC,SAAS,EAAE,CAAC,CAAC;IACbC,GAAG,EAAE;MACHC,cAAc,EAAE;IAClB;EACF,CAAC;EACDC,KAAK,EAAEC,8BAAc;EACrBC,cAAc,EAAEC;AAClB,CAAC;AAACC,OAAA,CAAApB,eAAA,GAAAA,eAAA"}
@@ -11,7 +11,7 @@ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/de
11
11
  var _parseShp = require("./lib/parsers/parse-shp");
12
12
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
13
13
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
14
- var VERSION = typeof "4.0.0-alpha.21" !== 'undefined' ? "4.0.0-alpha.21" : 'latest';
14
+ var VERSION = typeof "4.0.0-alpha.23" !== 'undefined' ? "4.0.0-alpha.23" : 'latest';
15
15
  var SHP_MAGIC_NUMBER = [0x00, 0x00, 0x27, 0x0a];
16
16
  exports.SHP_MAGIC_NUMBER = SHP_MAGIC_NUMBER;
17
17
  var SHPWorkerLoader = {
@@ -1,5 +1,5 @@
1
1
  import { parseDBF, parseDBFInBatches } from './lib/parsers/parse-dbf';
2
- const VERSION = typeof "4.0.0-alpha.21" !== 'undefined' ? "4.0.0-alpha.21" : 'latest';
2
+ const VERSION = typeof "4.0.0-alpha.23" !== 'undefined' ? "4.0.0-alpha.23" : 'latest';
3
3
  export const DBFWorkerLoader = {
4
4
  name: 'DBF',
5
5
  id: 'dbf',
@@ -1,3 +1,4 @@
1
+ import { parseInBatchesFromContext, parseFromContext } from '@loaders.gl/loader-utils';
1
2
  import { binaryToGeometry, transformGeoJsonCoords } from '@loaders.gl/gis';
2
3
  import { Proj4Projection } from '@math.gl/proj4';
3
4
  import { parseShx } from './parse-shx';
@@ -14,16 +15,16 @@ export async function* parseShapefileInBatches(asyncIterator, options, context)
14
15
  cpg,
15
16
  prj
16
17
  } = await loadShapefileSidecarFiles(options, context);
17
- const shapeIterable = await context.parseInBatches(asyncIterator, SHPLoader, options);
18
+ const shapeIterable = await parseInBatchesFromContext(asyncIterator, SHPLoader, options, context);
18
19
  let propertyIterable;
19
- const dbfResponse = await context.fetch(replaceExtension((context === null || context === void 0 ? void 0 : context.url) || '', 'dbf'));
20
- if (dbfResponse.ok) {
21
- propertyIterable = await context.parseInBatches(dbfResponse, DBFLoader, {
20
+ const dbfResponse = await (context === null || context === void 0 ? void 0 : context.fetch(replaceExtension((context === null || context === void 0 ? void 0 : context.url) || '', 'dbf')));
21
+ if (dbfResponse !== null && dbfResponse !== void 0 && dbfResponse.ok) {
22
+ propertyIterable = await parseInBatchesFromContext(dbfResponse, DBFLoader, {
22
23
  ...options,
23
24
  dbf: {
24
25
  encoding: cpg || 'latin1'
25
26
  }
26
- });
27
+ }, context);
27
28
  }
28
29
  let shapeHeader = (await shapeIterable.next()).value;
29
30
  if (shapeHeader && shapeHeader.batchType === 'metadata') {
@@ -77,16 +78,16 @@ export async function parseShapefile(arrayBuffer, options, context) {
77
78
  const {
78
79
  header,
79
80
  geometries
80
- } = await context.parse(arrayBuffer, SHPLoader, options);
81
+ } = await parseFromContext(arrayBuffer, SHPLoader, options, context);
81
82
  const geojsonGeometries = parseGeometries(geometries);
82
83
  let properties = [];
83
- const dbfResponse = await context.fetch(replaceExtension(context.url, 'dbf'));
84
- if (dbfResponse.ok) {
85
- properties = await context.parse(dbfResponse, DBFLoader, {
84
+ const dbfResponse = await (context === null || context === void 0 ? void 0 : context.fetch(replaceExtension(context === null || context === void 0 ? void 0 : context.url, 'dbf')));
85
+ if (dbfResponse !== null && dbfResponse !== void 0 && dbfResponse.ok) {
86
+ properties = await parseFromContext(dbfResponse, DBFLoader, {
86
87
  dbf: {
87
88
  encoding: cpg || 'latin1'
88
89
  }
89
- });
90
+ }, context);
90
91
  }
91
92
  let features = joinProperties(geojsonGeometries, properties);
92
93
  if (reproject) {
@@ -1 +1 @@
1
- {"version":3,"file":"parse-shapefile.js","names":["binaryToGeometry","transformGeoJsonCoords","Proj4Projection","parseShx","zipBatchIterators","SHPLoader","DBFLoader","parseShapefileInBatches","asyncIterator","options","context","reproject","_targetCrs","gis","shx","cpg","prj","loadShapefileSidecarFiles","shapeIterable","parseInBatches","propertyIterable","dbfResponse","fetch","replaceExtension","url","ok","dbf","encoding","shapeHeader","next","value","batchType","dbfHeader","iterator","item","geometries","properties","geojsonGeometries","parseGeometries","features","joinProperties","reprojectFeatures","header","data","parseShapefile","arrayBuffer","parse","geom","push","i","length","geometry","feature","type","sourceCrs","targetCrs","projection","from","to","coord","project","shxPromise","cpgPromise","prjPromise","Promise","all","shxResponse","cpgResponse","text","prjResponse","newExtension","baseName","basename","extension","extname","isUpperCase","toUpperCase","concat","extIndex","lastIndexOf","substr"],"sources":["../../../../src/lib/parsers/parse-shapefile.ts"],"sourcesContent":["// import type {Feature} from '@loaders.gl/gis';\nimport type {SHXOutput} from './parse-shx';\nimport type {SHPHeader} from './parse-shp-header';\nimport type {LoaderContext} from '@loaders.gl/loader-utils';\nimport type {ShapefileLoaderOptions} from './types';\n\nimport {binaryToGeometry, transformGeoJsonCoords} from '@loaders.gl/gis';\nimport {Proj4Projection} from '@math.gl/proj4';\nimport {parseShx} from './parse-shx';\nimport {zipBatchIterators} from '../streaming/zip-batch-iterators';\nimport {SHPLoader} from '../../shp-loader';\nimport {DBFLoader} from '../../dbf-loader';\n\ntype Feature = any;\ninterface ShapefileOutput {\n encoding?: string;\n prj?: string;\n shx?: SHXOutput;\n header: SHPHeader;\n data: object[];\n}\n/**\n * Parsing of file in batches\n */\n// eslint-disable-next-line max-statements, complexity\nexport async function* parseShapefileInBatches(\n asyncIterator: AsyncIterable<ArrayBuffer> | Iterable<ArrayBuffer>,\n options?: ShapefileLoaderOptions,\n context?: LoaderContext\n): AsyncIterable<ShapefileOutput> {\n const {reproject = false, _targetCrs = 'WGS84'} = options?.gis || {};\n const {shx, cpg, prj} = await loadShapefileSidecarFiles(options, context);\n\n // parse geometries\n // @ts-ignore context must be defined\n const shapeIterable: any = await context.parseInBatches(asyncIterator, SHPLoader, options);\n\n // parse properties\n let propertyIterable: any;\n // @ts-ignore context must be defined\n const dbfResponse = await context.fetch(replaceExtension(context?.url || '', 'dbf'));\n if (dbfResponse.ok) {\n // @ts-ignore context must be defined\n propertyIterable = await context.parseInBatches(dbfResponse, DBFLoader, {\n ...options,\n dbf: {encoding: cpg || 'latin1'}\n });\n }\n\n // When `options.metadata` is `true`, there's an extra initial `metadata`\n // object before the iterator starts. zipBatchIterators expects to receive\n // batches of Array objects, and will fail with non-iterable batches, so it's\n // important to skip over the first batch.\n let shapeHeader = (await shapeIterable.next()).value;\n if (shapeHeader && shapeHeader.batchType === 'metadata') {\n shapeHeader = (await shapeIterable.next()).value;\n }\n\n let dbfHeader: {batchType?: string} = {};\n if (propertyIterable) {\n dbfHeader = (await propertyIterable.next()).value;\n if (dbfHeader && dbfHeader.batchType === 'metadata') {\n dbfHeader = (await propertyIterable.next()).value;\n }\n }\n\n let iterator: any;\n if (propertyIterable) {\n iterator = zipBatchIterators(shapeIterable, propertyIterable);\n } else {\n iterator = shapeIterable;\n }\n\n for await (const item of iterator) {\n let geometries: any;\n let properties: any;\n if (!propertyIterable) {\n geometries = item;\n } else {\n [geometries, properties] = item;\n }\n\n const geojsonGeometries = parseGeometries(geometries);\n let features = joinProperties(geojsonGeometries, properties);\n if (reproject) {\n // @ts-ignore\n features = reprojectFeatures(features, prj, _targetCrs);\n }\n yield {\n encoding: cpg,\n prj,\n shx,\n header: shapeHeader,\n data: features\n };\n }\n}\n\n/**\n * Parse shapefile\n *\n * @param arrayBuffer\n * @param options\n * @param context\n * @returns output of shapefile\n */\nexport async function parseShapefile(\n arrayBuffer: ArrayBuffer,\n options?: ShapefileLoaderOptions,\n context?: LoaderContext\n): Promise<ShapefileOutput> {\n const {reproject = false, _targetCrs = 'WGS84'} = options?.gis || {};\n const {shx, cpg, prj} = await loadShapefileSidecarFiles(options, context);\n\n // parse geometries\n // @ts-ignore context must be defined\n const {header, geometries} = await context.parse(arrayBuffer, SHPLoader, options); // {shp: shx}\n\n const geojsonGeometries = parseGeometries(geometries);\n\n // parse properties\n let properties = [];\n\n // @ts-ignore context must be defined\n const dbfResponse = await context.fetch(replaceExtension(context.url, 'dbf'));\n if (dbfResponse.ok) {\n // @ts-ignore context must be defined\n properties = await context.parse(dbfResponse, DBFLoader, {dbf: {encoding: cpg || 'latin1'}});\n }\n\n let features = joinProperties(geojsonGeometries, properties);\n if (reproject) {\n features = reprojectFeatures(features, prj, _targetCrs);\n }\n\n return {\n encoding: cpg,\n prj,\n shx,\n header,\n data: features\n };\n}\n\n/**\n * Parse geometries\n *\n * @param geometries\n * @returns geometries as an array\n */\nfunction parseGeometries(geometries: any[]): any[] {\n const geojsonGeometries: any[] = [];\n for (const geom of geometries) {\n geojsonGeometries.push(binaryToGeometry(geom));\n }\n return geojsonGeometries;\n}\n\n/**\n * Join properties and geometries into features\n *\n * @param geometries [description]\n * @param properties [description]\n * @return [description]\n */\nfunction joinProperties(geometries: object[], properties: object[]): Feature[] {\n const features: Feature[] = [];\n for (let i = 0; i < geometries.length; i++) {\n const geometry = geometries[i];\n const feature: Feature = {\n type: 'Feature',\n geometry,\n // properties can be undefined if dbfResponse above was empty\n properties: (properties && properties[i]) || {}\n };\n features.push(feature);\n }\n\n return features;\n}\n\n/**\n * Reproject GeoJSON features to output CRS\n *\n * @param features parsed GeoJSON features\n * @param sourceCrs source coordinate reference system\n * @param targetCrs †arget coordinate reference system\n * @return Reprojected Features\n */\nfunction reprojectFeatures(features: Feature[], sourceCrs?: string, targetCrs?: string): Feature[] {\n if (!sourceCrs && !targetCrs) {\n return features;\n }\n\n const projection = new Proj4Projection({from: sourceCrs || 'WGS84', to: targetCrs || 'WGS84'});\n return transformGeoJsonCoords(features, (coord) => projection.project(coord));\n}\n\n/**\n *\n * @param options\n * @param context\n * @returns Promise\n */\n// eslint-disable-next-line max-statements\nexport async function loadShapefileSidecarFiles(\n options?: object,\n context?: LoaderContext\n): Promise<{\n shx?: SHXOutput;\n cpg?: string;\n prj?: string;\n}> {\n // Attempt a parallel load of the small sidecar files\n // @ts-ignore context must be defined\n const {url, fetch} = context;\n const shxPromise = fetch(replaceExtension(url, 'shx'));\n const cpgPromise = fetch(replaceExtension(url, 'cpg'));\n const prjPromise = fetch(replaceExtension(url, 'prj'));\n await Promise.all([shxPromise, cpgPromise, prjPromise]);\n\n let shx: SHXOutput | undefined;\n let cpg: string | undefined;\n let prj: string | undefined;\n\n const shxResponse = await shxPromise;\n if (shxResponse.ok) {\n const arrayBuffer = await shxResponse.arrayBuffer();\n shx = parseShx(arrayBuffer);\n }\n\n const cpgResponse = await cpgPromise;\n if (cpgResponse.ok) {\n cpg = await cpgResponse.text();\n }\n\n const prjResponse = await prjPromise;\n if (prjResponse.ok) {\n prj = await prjResponse.text();\n }\n\n return {\n shx,\n cpg,\n prj\n };\n}\n\n/**\n * Replace the extension at the end of a path.\n *\n * Matches the case of new extension with the case of the original file extension,\n * to increase the chance of finding files without firing off a request storm looking for various case combinations\n *\n * NOTE: Extensions can be both lower and uppercase\n * per spec, extensions should be lower case, but that doesn't mean they always are. See:\n * calvinmetcalf/shapefile-js#64, mapserver/mapserver#4712\n * https://trac.osgeo.org/mapserver/ticket/166\n */\nexport function replaceExtension(url: string, newExtension: string): string {\n const baseName = basename(url);\n const extension = extname(url);\n const isUpperCase = extension === extension.toUpperCase();\n if (isUpperCase) {\n newExtension = newExtension.toUpperCase();\n }\n return `${baseName}.${newExtension}`;\n}\n\n// NOTE - this gives the entire path minus extension (i.e. NOT same as path.basename)\n/**\n * @param url\n * @returns string\n */\nfunction basename(url: string): string {\n const extIndex = url && url.lastIndexOf('.');\n if (typeof extIndex === 'number') {\n return extIndex >= 0 ? url.substr(0, extIndex) : '';\n }\n return extIndex;\n}\n/**\n * @param url\n * @returns string\n */\nfunction extname(url: string): string {\n const extIndex = url && url.lastIndexOf('.');\n if (typeof extIndex === 'number') {\n return extIndex >= 0 ? url.substr(extIndex + 1) : '';\n }\n return extIndex;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"parse-shapefile.js","names":["parseInBatchesFromContext","parseFromContext","binaryToGeometry","transformGeoJsonCoords","Proj4Projection","parseShx","zipBatchIterators","SHPLoader","DBFLoader","parseShapefileInBatches","asyncIterator","options","context","reproject","_targetCrs","gis","shx","cpg","prj","loadShapefileSidecarFiles","shapeIterable","propertyIterable","dbfResponse","fetch","replaceExtension","url","ok","dbf","encoding","shapeHeader","next","value","batchType","dbfHeader","iterator","item","geometries","properties","geojsonGeometries","parseGeometries","features","joinProperties","reprojectFeatures","header","data","parseShapefile","arrayBuffer","geom","push","i","length","geometry","feature","type","sourceCrs","targetCrs","projection","from","to","coord","project","shxPromise","cpgPromise","prjPromise","Promise","all","shxResponse","cpgResponse","text","prjResponse","newExtension","baseName","basename","extension","extname","isUpperCase","toUpperCase","concat","extIndex","lastIndexOf","substr"],"sources":["../../../../src/lib/parsers/parse-shapefile.ts"],"sourcesContent":["// import type {Feature} from '@loaders.gl/gis';\nimport {LoaderContext, parseInBatchesFromContext, parseFromContext} from '@loaders.gl/loader-utils';\nimport {binaryToGeometry, transformGeoJsonCoords} from '@loaders.gl/gis';\nimport {Proj4Projection} from '@math.gl/proj4';\n\nimport type {SHXOutput} from './parse-shx';\nimport type {SHPHeader} from './parse-shp-header';\nimport type {ShapefileLoaderOptions} from './types';\nimport {parseShx} from './parse-shx';\nimport {zipBatchIterators} from '../streaming/zip-batch-iterators';\nimport {SHPLoader} from '../../shp-loader';\nimport {DBFLoader} from '../../dbf-loader';\n\ntype Feature = any;\ninterface ShapefileOutput {\n encoding?: string;\n prj?: string;\n shx?: SHXOutput;\n header: SHPHeader;\n data: object[];\n}\n/**\n * Parsing of file in batches\n */\n// eslint-disable-next-line max-statements, complexity\nexport async function* parseShapefileInBatches(\n asyncIterator: AsyncIterable<ArrayBuffer> | Iterable<ArrayBuffer>,\n options?: ShapefileLoaderOptions,\n context?: LoaderContext\n): AsyncIterable<ShapefileOutput> {\n const {reproject = false, _targetCrs = 'WGS84'} = options?.gis || {};\n const {shx, cpg, prj} = await loadShapefileSidecarFiles(options, context);\n\n // parse geometries\n const shapeIterable: any = await parseInBatchesFromContext(\n asyncIterator,\n SHPLoader,\n options,\n context!\n );\n\n // parse properties\n let propertyIterable: any;\n const dbfResponse = await context?.fetch(replaceExtension(context?.url || '', 'dbf'));\n if (dbfResponse?.ok) {\n propertyIterable = await parseInBatchesFromContext(\n dbfResponse as any,\n DBFLoader,\n {\n ...options,\n dbf: {encoding: cpg || 'latin1'}\n },\n context!\n );\n }\n\n // When `options.metadata` is `true`, there's an extra initial `metadata`\n // object before the iterator starts. zipBatchIterators expects to receive\n // batches of Array objects, and will fail with non-iterable batches, so it's\n // important to skip over the first batch.\n let shapeHeader = (await shapeIterable.next()).value;\n if (shapeHeader && shapeHeader.batchType === 'metadata') {\n shapeHeader = (await shapeIterable.next()).value;\n }\n\n let dbfHeader: {batchType?: string} = {};\n if (propertyIterable) {\n dbfHeader = (await propertyIterable.next()).value;\n if (dbfHeader && dbfHeader.batchType === 'metadata') {\n dbfHeader = (await propertyIterable.next()).value;\n }\n }\n\n let iterator: any;\n if (propertyIterable) {\n iterator = zipBatchIterators(shapeIterable, propertyIterable);\n } else {\n iterator = shapeIterable;\n }\n\n for await (const item of iterator) {\n let geometries: any;\n let properties: any;\n if (!propertyIterable) {\n geometries = item;\n } else {\n [geometries, properties] = item;\n }\n\n const geojsonGeometries = parseGeometries(geometries);\n let features = joinProperties(geojsonGeometries, properties);\n if (reproject) {\n // @ts-ignore\n features = reprojectFeatures(features, prj, _targetCrs);\n }\n yield {\n encoding: cpg,\n prj,\n shx,\n header: shapeHeader,\n data: features\n };\n }\n}\n\n/**\n * Parse shapefile\n *\n * @param arrayBuffer\n * @param options\n * @param context\n * @returns output of shapefile\n */\nexport async function parseShapefile(\n arrayBuffer: ArrayBuffer,\n options?: ShapefileLoaderOptions,\n context?: LoaderContext\n): Promise<ShapefileOutput> {\n const {reproject = false, _targetCrs = 'WGS84'} = options?.gis || {};\n const {shx, cpg, prj} = await loadShapefileSidecarFiles(options, context);\n\n // parse geometries\n const {header, geometries} = await parseFromContext(arrayBuffer, SHPLoader, options, context!); // {shp: shx}\n\n const geojsonGeometries = parseGeometries(geometries);\n\n // parse properties\n let properties = [];\n\n const dbfResponse = await context?.fetch(replaceExtension(context?.url!, 'dbf'));\n if (dbfResponse?.ok) {\n properties = await parseFromContext(\n dbfResponse as any,\n DBFLoader,\n {dbf: {encoding: cpg || 'latin1'}},\n context!\n );\n }\n\n let features = joinProperties(geojsonGeometries, properties);\n if (reproject) {\n features = reprojectFeatures(features, prj, _targetCrs);\n }\n\n return {\n encoding: cpg,\n prj,\n shx,\n header,\n data: features\n };\n}\n\n/**\n * Parse geometries\n *\n * @param geometries\n * @returns geometries as an array\n */\nfunction parseGeometries(geometries: any[]): any[] {\n const geojsonGeometries: any[] = [];\n for (const geom of geometries) {\n geojsonGeometries.push(binaryToGeometry(geom));\n }\n return geojsonGeometries;\n}\n\n/**\n * Join properties and geometries into features\n *\n * @param geometries [description]\n * @param properties [description]\n * @return [description]\n */\nfunction joinProperties(geometries: object[], properties: object[]): Feature[] {\n const features: Feature[] = [];\n for (let i = 0; i < geometries.length; i++) {\n const geometry = geometries[i];\n const feature: Feature = {\n type: 'Feature',\n geometry,\n // properties can be undefined if dbfResponse above was empty\n properties: (properties && properties[i]) || {}\n };\n features.push(feature);\n }\n\n return features;\n}\n\n/**\n * Reproject GeoJSON features to output CRS\n *\n * @param features parsed GeoJSON features\n * @param sourceCrs source coordinate reference system\n * @param targetCrs †arget coordinate reference system\n * @return Reprojected Features\n */\nfunction reprojectFeatures(features: Feature[], sourceCrs?: string, targetCrs?: string): Feature[] {\n if (!sourceCrs && !targetCrs) {\n return features;\n }\n\n const projection = new Proj4Projection({from: sourceCrs || 'WGS84', to: targetCrs || 'WGS84'});\n return transformGeoJsonCoords(features, (coord) => projection.project(coord));\n}\n\n/**\n *\n * @param options\n * @param context\n * @returns Promise\n */\n// eslint-disable-next-line max-statements\nexport async function loadShapefileSidecarFiles(\n options?: object,\n context?: LoaderContext\n): Promise<{\n shx?: SHXOutput;\n cpg?: string;\n prj?: string;\n}> {\n // Attempt a parallel load of the small sidecar files\n // @ts-ignore context must be defined\n const {url, fetch} = context;\n const shxPromise = fetch(replaceExtension(url, 'shx'));\n const cpgPromise = fetch(replaceExtension(url, 'cpg'));\n const prjPromise = fetch(replaceExtension(url, 'prj'));\n await Promise.all([shxPromise, cpgPromise, prjPromise]);\n\n let shx: SHXOutput | undefined;\n let cpg: string | undefined;\n let prj: string | undefined;\n\n const shxResponse = await shxPromise;\n if (shxResponse.ok) {\n const arrayBuffer = await shxResponse.arrayBuffer();\n shx = parseShx(arrayBuffer);\n }\n\n const cpgResponse = await cpgPromise;\n if (cpgResponse.ok) {\n cpg = await cpgResponse.text();\n }\n\n const prjResponse = await prjPromise;\n if (prjResponse.ok) {\n prj = await prjResponse.text();\n }\n\n return {\n shx,\n cpg,\n prj\n };\n}\n\n/**\n * Replace the extension at the end of a path.\n *\n * Matches the case of new extension with the case of the original file extension,\n * to increase the chance of finding files without firing off a request storm looking for various case combinations\n *\n * NOTE: Extensions can be both lower and uppercase\n * per spec, extensions should be lower case, but that doesn't mean they always are. See:\n * calvinmetcalf/shapefile-js#64, mapserver/mapserver#4712\n * https://trac.osgeo.org/mapserver/ticket/166\n */\nexport function replaceExtension(url: string, newExtension: string): string {\n const baseName = basename(url);\n const extension = extname(url);\n const isUpperCase = extension === extension.toUpperCase();\n if (isUpperCase) {\n newExtension = newExtension.toUpperCase();\n }\n return `${baseName}.${newExtension}`;\n}\n\n// NOTE - this gives the entire path minus extension (i.e. NOT same as path.basename)\n/**\n * @param url\n * @returns string\n */\nfunction basename(url: string): string {\n const extIndex = url && url.lastIndexOf('.');\n if (typeof extIndex === 'number') {\n return extIndex >= 0 ? url.substr(0, extIndex) : '';\n }\n return extIndex;\n}\n/**\n * @param url\n * @returns string\n */\nfunction extname(url: string): string {\n const extIndex = url && url.lastIndexOf('.');\n if (typeof extIndex === 'number') {\n return extIndex >= 0 ? url.substr(extIndex + 1) : '';\n }\n return extIndex;\n}\n"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { SHP_MAGIC_NUMBER } from './shp-loader';
2
2
  import { parseShapefile, parseShapefileInBatches } from './lib/parsers/parse-shapefile';
3
- const VERSION = typeof "4.0.0-alpha.21" !== 'undefined' ? "4.0.0-alpha.21" : 'latest';
3
+ const VERSION = typeof "4.0.0-alpha.23" !== 'undefined' ? "4.0.0-alpha.23" : 'latest';
4
4
  export const ShapefileLoader = {
5
5
  name: 'Shapefile',
6
6
  id: 'shapefile',
@@ -19,5 +19,4 @@ export const ShapefileLoader = {
19
19
  parse: parseShapefile,
20
20
  parseInBatches: parseShapefileInBatches
21
21
  };
22
- export const _typecheckShapefileLoader = ShapefileLoader;
23
22
  //# sourceMappingURL=shapefile-loader.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"shapefile-loader.js","names":["SHP_MAGIC_NUMBER","parseShapefile","parseShapefileInBatches","VERSION","ShapefileLoader","name","id","module","version","category","extensions","mimeTypes","tests","Uint8Array","buffer","options","shapefile","shp","_maxDimensions","parse","parseInBatches","_typecheckShapefileLoader"],"sources":["../../src/shapefile-loader.ts"],"sourcesContent":["import type {LoaderWithParser} from '@loaders.gl/loader-utils';\nimport {SHP_MAGIC_NUMBER} from './shp-loader';\nimport {parseShapefile, parseShapefileInBatches} from './lib/parsers/parse-shapefile';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\n/**\n * Shapefile loader\n * @note Shapefile is multifile format and requires providing additional files\n */\nexport const ShapefileLoader = {\n name: 'Shapefile',\n id: 'shapefile',\n module: 'shapefile',\n version: VERSION,\n category: 'geometry',\n extensions: ['shp'],\n mimeTypes: ['application/octet-stream'],\n tests: [new Uint8Array(SHP_MAGIC_NUMBER).buffer],\n options: {\n shapefile: {},\n shp: {\n _maxDimensions: 4\n }\n },\n parse: parseShapefile,\n parseInBatches: parseShapefileInBatches\n};\n\nexport const _typecheckShapefileLoader: LoaderWithParser = ShapefileLoader;\n"],"mappings":"AACA,SAAQA,gBAAgB,QAAO,cAAc;AAC7C,SAAQC,cAAc,EAAEC,uBAAuB,QAAO,+BAA+B;AAIrF,MAAMC,OAAO,GAAG,uBAAkB,KAAK,WAAW,sBAAiB,QAAQ;AAM3E,OAAO,MAAMC,eAAe,GAAG;EAC7BC,IAAI,EAAE,WAAW;EACjBC,EAAE,EAAE,WAAW;EACfC,MAAM,EAAE,WAAW;EACnBC,OAAO,EAAEL,OAAO;EAChBM,QAAQ,EAAE,UAAU;EACpBC,UAAU,EAAE,CAAC,KAAK,CAAC;EACnBC,SAAS,EAAE,CAAC,0BAA0B,CAAC;EACvCC,KAAK,EAAE,CAAC,IAAIC,UAAU,CAACb,gBAAgB,CAAC,CAACc,MAAM,CAAC;EAChDC,OAAO,EAAE;IACPC,SAAS,EAAE,CAAC,CAAC;IACbC,GAAG,EAAE;MACHC,cAAc,EAAE;IAClB;EACF,CAAC;EACDC,KAAK,EAAElB,cAAc;EACrBmB,cAAc,EAAElB;AAClB,CAAC;AAED,OAAO,MAAMmB,yBAA2C,GAAGjB,eAAe"}
1
+ {"version":3,"file":"shapefile-loader.js","names":["SHP_MAGIC_NUMBER","parseShapefile","parseShapefileInBatches","VERSION","ShapefileLoader","name","id","module","version","category","extensions","mimeTypes","tests","Uint8Array","buffer","options","shapefile","shp","_maxDimensions","parse","parseInBatches"],"sources":["../../src/shapefile-loader.ts"],"sourcesContent":["import type {LoaderOptions, LoaderWithParser} from '@loaders.gl/loader-utils';\nimport {SHP_MAGIC_NUMBER} from './shp-loader';\nimport {parseShapefile, parseShapefileInBatches} from './lib/parsers/parse-shapefile';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\n/**\n * Shapefile loader\n * @note Shapefile is multifile format and requires providing additional files\n */\nexport const ShapefileLoader: LoaderWithParser<any, any, LoaderOptions> = {\n name: 'Shapefile',\n id: 'shapefile',\n module: 'shapefile',\n version: VERSION,\n category: 'geometry',\n extensions: ['shp'],\n mimeTypes: ['application/octet-stream'],\n tests: [new Uint8Array(SHP_MAGIC_NUMBER).buffer],\n options: {\n shapefile: {},\n shp: {\n _maxDimensions: 4\n }\n },\n parse: parseShapefile,\n parseInBatches: parseShapefileInBatches\n};\n"],"mappings":"AACA,SAAQA,gBAAgB,QAAO,cAAc;AAC7C,SAAQC,cAAc,EAAEC,uBAAuB,QAAO,+BAA+B;AAIrF,MAAMC,OAAO,GAAG,uBAAkB,KAAK,WAAW,sBAAiB,QAAQ;AAM3E,OAAO,MAAMC,eAA0D,GAAG;EACxEC,IAAI,EAAE,WAAW;EACjBC,EAAE,EAAE,WAAW;EACfC,MAAM,EAAE,WAAW;EACnBC,OAAO,EAAEL,OAAO;EAChBM,QAAQ,EAAE,UAAU;EACpBC,UAAU,EAAE,CAAC,KAAK,CAAC;EACnBC,SAAS,EAAE,CAAC,0BAA0B,CAAC;EACvCC,KAAK,EAAE,CAAC,IAAIC,UAAU,CAACb,gBAAgB,CAAC,CAACc,MAAM,CAAC;EAChDC,OAAO,EAAE;IACPC,SAAS,EAAE,CAAC,CAAC;IACbC,GAAG,EAAE;MACHC,cAAc,EAAE;IAClB;EACF,CAAC;EACDC,KAAK,EAAElB,cAAc;EACrBmB,cAAc,EAAElB;AAClB,CAAC"}
@@ -1,5 +1,5 @@
1
1
  import { parseSHP, parseSHPInBatches } from './lib/parsers/parse-shp';
2
- const VERSION = typeof "4.0.0-alpha.21" !== 'undefined' ? "4.0.0-alpha.21" : 'latest';
2
+ const VERSION = typeof "4.0.0-alpha.23" !== 'undefined' ? "4.0.0-alpha.23" : 'latest';
3
3
  export const SHP_MAGIC_NUMBER = [0x00, 0x00, 0x27, 0x0a];
4
4
  export const SHPWorkerLoader = {
5
5
  name: 'SHP',
@@ -1,6 +1,6 @@
1
+ import { LoaderContext } from '@loaders.gl/loader-utils';
1
2
  import type { SHXOutput } from './parse-shx';
2
3
  import type { SHPHeader } from './parse-shp-header';
3
- import type { LoaderContext } from '@loaders.gl/loader-utils';
4
4
  import type { ShapefileLoaderOptions } from './types';
5
5
  interface ShapefileOutput {
6
6
  encoding?: string;
@@ -1 +1 @@
1
- {"version":3,"file":"parse-shapefile.d.ts","sourceRoot":"","sources":["../../../src/lib/parsers/parse-shapefile.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,aAAa,CAAC;AAC3C,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,oBAAoB,CAAC;AAClD,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,0BAA0B,CAAC;AAC5D,OAAO,KAAK,EAAC,sBAAsB,EAAC,MAAM,SAAS,CAAC;AAUpD,UAAU,eAAe;IACvB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,SAAS,CAAC;IAChB,MAAM,EAAE,SAAS,CAAC;IAClB,IAAI,EAAE,MAAM,EAAE,CAAC;CAChB;AACD;;GAEG;AAEH,wBAAuB,uBAAuB,CAC5C,aAAa,EAAE,aAAa,CAAC,WAAW,CAAC,GAAG,QAAQ,CAAC,WAAW,CAAC,EACjE,OAAO,CAAC,EAAE,sBAAsB,EAChC,OAAO,CAAC,EAAE,aAAa,GACtB,aAAa,CAAC,eAAe,CAAC,CAmEhC;AAED;;;;;;;GAOG;AACH,wBAAsB,cAAc,CAClC,WAAW,EAAE,WAAW,EACxB,OAAO,CAAC,EAAE,sBAAsB,EAChC,OAAO,CAAC,EAAE,aAAa,GACtB,OAAO,CAAC,eAAe,CAAC,CAgC1B;AAwDD;;;;;GAKG;AAEH,wBAAsB,yBAAyB,CAC7C,OAAO,CAAC,EAAE,MAAM,EAChB,OAAO,CAAC,EAAE,aAAa,GACtB,OAAO,CAAC;IACT,GAAG,CAAC,EAAE,SAAS,CAAC;IAChB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;CACd,CAAC,CAkCD;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,MAAM,CAQ1E"}
1
+ {"version":3,"file":"parse-shapefile.d.ts","sourceRoot":"","sources":["../../../src/lib/parsers/parse-shapefile.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,aAAa,EAA8C,MAAM,0BAA0B,CAAC;AAIpG,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,aAAa,CAAC;AAC3C,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,oBAAoB,CAAC;AAClD,OAAO,KAAK,EAAC,sBAAsB,EAAC,MAAM,SAAS,CAAC;AAOpD,UAAU,eAAe;IACvB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,SAAS,CAAC;IAChB,MAAM,EAAE,SAAS,CAAC;IAClB,IAAI,EAAE,MAAM,EAAE,CAAC;CAChB;AACD;;GAEG;AAEH,wBAAuB,uBAAuB,CAC5C,aAAa,EAAE,aAAa,CAAC,WAAW,CAAC,GAAG,QAAQ,CAAC,WAAW,CAAC,EACjE,OAAO,CAAC,EAAE,sBAAsB,EAChC,OAAO,CAAC,EAAE,aAAa,GACtB,aAAa,CAAC,eAAe,CAAC,CA0EhC;AAED;;;;;;;GAOG;AACH,wBAAsB,cAAc,CAClC,WAAW,EAAE,WAAW,EACxB,OAAO,CAAC,EAAE,sBAAsB,EAChC,OAAO,CAAC,EAAE,aAAa,GACtB,OAAO,CAAC,eAAe,CAAC,CAkC1B;AAwDD;;;;;GAKG;AAEH,wBAAsB,yBAAyB,CAC7C,OAAO,CAAC,EAAE,MAAM,EAChB,OAAO,CAAC,EAAE,aAAa,GACtB,OAAO,CAAC;IACT,GAAG,CAAC,EAAE,SAAS,CAAC;IAChB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;CACd,CAAC,CAkCD;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,MAAM,CAQ1E"}
@@ -1,6 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.replaceExtension = exports.loadShapefileSidecarFiles = exports.parseShapefile = exports.parseShapefileInBatches = void 0;
4
+ // import type {Feature} from '@loaders.gl/gis';
5
+ const loader_utils_1 = require("@loaders.gl/loader-utils");
4
6
  const gis_1 = require("@loaders.gl/gis");
5
7
  const proj4_1 = require("@math.gl/proj4");
6
8
  const parse_shx_1 = require("./parse-shx");
@@ -15,18 +17,15 @@ async function* parseShapefileInBatches(asyncIterator, options, context) {
15
17
  const { reproject = false, _targetCrs = 'WGS84' } = options?.gis || {};
16
18
  const { shx, cpg, prj } = await loadShapefileSidecarFiles(options, context);
17
19
  // parse geometries
18
- // @ts-ignore context must be defined
19
- const shapeIterable = await context.parseInBatches(asyncIterator, shp_loader_1.SHPLoader, options);
20
+ const shapeIterable = await (0, loader_utils_1.parseInBatchesFromContext)(asyncIterator, shp_loader_1.SHPLoader, options, context);
20
21
  // parse properties
21
22
  let propertyIterable;
22
- // @ts-ignore context must be defined
23
- const dbfResponse = await context.fetch(replaceExtension(context?.url || '', 'dbf'));
24
- if (dbfResponse.ok) {
25
- // @ts-ignore context must be defined
26
- propertyIterable = await context.parseInBatches(dbfResponse, dbf_loader_1.DBFLoader, {
23
+ const dbfResponse = await context?.fetch(replaceExtension(context?.url || '', 'dbf'));
24
+ if (dbfResponse?.ok) {
25
+ propertyIterable = await (0, loader_utils_1.parseInBatchesFromContext)(dbfResponse, dbf_loader_1.DBFLoader, {
27
26
  ...options,
28
27
  dbf: { encoding: cpg || 'latin1' }
29
- });
28
+ }, context);
30
29
  }
31
30
  // When `options.metadata` is `true`, there's an extra initial `metadata`
32
31
  // object before the iterator starts. zipBatchIterators expects to receive
@@ -87,16 +86,13 @@ async function parseShapefile(arrayBuffer, options, context) {
87
86
  const { reproject = false, _targetCrs = 'WGS84' } = options?.gis || {};
88
87
  const { shx, cpg, prj } = await loadShapefileSidecarFiles(options, context);
89
88
  // parse geometries
90
- // @ts-ignore context must be defined
91
- const { header, geometries } = await context.parse(arrayBuffer, shp_loader_1.SHPLoader, options); // {shp: shx}
89
+ const { header, geometries } = await (0, loader_utils_1.parseFromContext)(arrayBuffer, shp_loader_1.SHPLoader, options, context); // {shp: shx}
92
90
  const geojsonGeometries = parseGeometries(geometries);
93
91
  // parse properties
94
92
  let properties = [];
95
- // @ts-ignore context must be defined
96
- const dbfResponse = await context.fetch(replaceExtension(context.url, 'dbf'));
97
- if (dbfResponse.ok) {
98
- // @ts-ignore context must be defined
99
- properties = await context.parse(dbfResponse, dbf_loader_1.DBFLoader, { dbf: { encoding: cpg || 'latin1' } });
93
+ const dbfResponse = await context?.fetch(replaceExtension(context?.url, 'dbf'));
94
+ if (dbfResponse?.ok) {
95
+ properties = await (0, loader_utils_1.parseFromContext)(dbfResponse, dbf_loader_1.DBFLoader, { dbf: { encoding: cpg || 'latin1' } }, context);
100
96
  }
101
97
  let features = joinProperties(geojsonGeometries, properties);
102
98
  if (reproject) {
@@ -1,26 +1,7 @@
1
- import type { LoaderWithParser } from '@loaders.gl/loader-utils';
2
- import { parseShapefile, parseShapefileInBatches } from './lib/parsers/parse-shapefile';
1
+ import type { LoaderOptions, LoaderWithParser } from '@loaders.gl/loader-utils';
3
2
  /**
4
3
  * Shapefile loader
5
4
  * @note Shapefile is multifile format and requires providing additional files
6
5
  */
7
- export declare const ShapefileLoader: {
8
- name: string;
9
- id: string;
10
- module: string;
11
- version: any;
12
- category: string;
13
- extensions: string[];
14
- mimeTypes: string[];
15
- tests: ArrayBufferLike[];
16
- options: {
17
- shapefile: {};
18
- shp: {
19
- _maxDimensions: number;
20
- };
21
- };
22
- parse: typeof parseShapefile;
23
- parseInBatches: typeof parseShapefileInBatches;
24
- };
25
- export declare const _typecheckShapefileLoader: LoaderWithParser;
6
+ export declare const ShapefileLoader: LoaderWithParser<any, any, LoaderOptions>;
26
7
  //# sourceMappingURL=shapefile-loader.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"shapefile-loader.d.ts","sourceRoot":"","sources":["../src/shapefile-loader.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,gBAAgB,EAAC,MAAM,0BAA0B,CAAC;AAE/D,OAAO,EAAC,cAAc,EAAE,uBAAuB,EAAC,MAAM,+BAA+B,CAAC;AAMtF;;;GAGG;AACH,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;;;CAiB3B,CAAC;AAEF,eAAO,MAAM,yBAAyB,EAAE,gBAAkC,CAAC"}
1
+ {"version":3,"file":"shapefile-loader.d.ts","sourceRoot":"","sources":["../src/shapefile-loader.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,aAAa,EAAE,gBAAgB,EAAC,MAAM,0BAA0B,CAAC;AAQ9E;;;GAGG;AACH,eAAO,MAAM,eAAe,EAAE,gBAAgB,CAAC,GAAG,EAAE,GAAG,EAAE,aAAa,CAiBrE,CAAC"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports._typecheckShapefileLoader = exports.ShapefileLoader = void 0;
3
+ exports.ShapefileLoader = void 0;
4
4
  const shp_loader_1 = require("./shp-loader");
5
5
  const parse_shapefile_1 = require("./lib/parsers/parse-shapefile");
6
6
  // __VERSION__ is injected by babel-plugin-version-inline
@@ -28,4 +28,3 @@ exports.ShapefileLoader = {
28
28
  parse: parse_shapefile_1.parseShapefile,
29
29
  parseInBatches: parse_shapefile_1.parseShapefileInBatches
30
30
  };
31
- exports._typecheckShapefileLoader = exports.ShapefileLoader;
@@ -430,7 +430,7 @@
430
430
  }
431
431
 
432
432
  // src/shp-loader.ts
433
- var VERSION = true ? "4.0.0-alpha.21" : "latest";
433
+ var VERSION = true ? "4.0.0-alpha.23" : "latest";
434
434
  var SHP_MAGIC_NUMBER2 = [0, 0, 39, 10];
435
435
  var SHPWorkerLoader = {
436
436
  name: "SHP",
@@ -581,7 +581,7 @@
581
581
  options,
582
582
  context: {
583
583
  ...context,
584
- parse: parseOnMainThread
584
+ _parse: parseOnMainThread
585
585
  }
586
586
  });
587
587
  WorkerBody.postMessage("done", { result });
@@ -594,7 +594,7 @@
594
594
  }
595
595
  };
596
596
  }
597
- function parseOnMainThread(arrayBuffer, options) {
597
+ function parseOnMainThread(arrayBuffer, loader, options, context) {
598
598
  return new Promise((resolve, reject) => {
599
599
  const id = requestId++;
600
600
  const onMessage = (type, payload2) => {
@@ -618,7 +618,12 @@
618
618
  WorkerBody.postMessage("process", payload);
619
619
  });
620
620
  }
621
- async function parseData({ loader, arrayBuffer, options, context }) {
621
+ async function parseData({
622
+ loader,
623
+ arrayBuffer,
624
+ options,
625
+ context
626
+ }) {
622
627
  let data;
623
628
  let parser;
624
629
  if (loader.parseSync || loader.parse) {
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@loaders.gl/shapefile",
3
3
  "description": "Loader for the Shapefile Format",
4
- "version": "4.0.0-alpha.21",
4
+ "version": "4.0.0-alpha.23",
5
5
  "license": "MIT",
6
6
  "publishConfig": {
7
7
  "access": "public"
@@ -37,10 +37,10 @@
37
37
  "build-worker-dbf": "esbuild src/workers/dbf-worker.ts --bundle --outfile=dist/dbf-worker.js --define:__VERSION__=\\\"$npm_package_version\\\""
38
38
  },
39
39
  "dependencies": {
40
- "@loaders.gl/gis": "4.0.0-alpha.21",
41
- "@loaders.gl/loader-utils": "4.0.0-alpha.21",
42
- "@loaders.gl/schema": "4.0.0-alpha.21",
40
+ "@loaders.gl/gis": "4.0.0-alpha.23",
41
+ "@loaders.gl/loader-utils": "4.0.0-alpha.23",
42
+ "@loaders.gl/schema": "4.0.0-alpha.23",
43
43
  "@math.gl/proj4": "^3.5.1"
44
44
  },
45
- "gitHead": "df5d670b136192b26941396e944f9c46be788e83"
45
+ "gitHead": "e212f2a0c0e342f7cb65ce84fa2ff39f64b7d94b"
46
46
  }
@@ -1,11 +1,11 @@
1
1
  // import type {Feature} from '@loaders.gl/gis';
2
+ import {LoaderContext, parseInBatchesFromContext, parseFromContext} from '@loaders.gl/loader-utils';
3
+ import {binaryToGeometry, transformGeoJsonCoords} from '@loaders.gl/gis';
4
+ import {Proj4Projection} from '@math.gl/proj4';
5
+
2
6
  import type {SHXOutput} from './parse-shx';
3
7
  import type {SHPHeader} from './parse-shp-header';
4
- import type {LoaderContext} from '@loaders.gl/loader-utils';
5
8
  import type {ShapefileLoaderOptions} from './types';
6
-
7
- import {binaryToGeometry, transformGeoJsonCoords} from '@loaders.gl/gis';
8
- import {Proj4Projection} from '@math.gl/proj4';
9
9
  import {parseShx} from './parse-shx';
10
10
  import {zipBatchIterators} from '../streaming/zip-batch-iterators';
11
11
  import {SHPLoader} from '../../shp-loader';
@@ -32,19 +32,26 @@ export async function* parseShapefileInBatches(
32
32
  const {shx, cpg, prj} = await loadShapefileSidecarFiles(options, context);
33
33
 
34
34
  // parse geometries
35
- // @ts-ignore context must be defined
36
- const shapeIterable: any = await context.parseInBatches(asyncIterator, SHPLoader, options);
35
+ const shapeIterable: any = await parseInBatchesFromContext(
36
+ asyncIterator,
37
+ SHPLoader,
38
+ options,
39
+ context!
40
+ );
37
41
 
38
42
  // parse properties
39
43
  let propertyIterable: any;
40
- // @ts-ignore context must be defined
41
- const dbfResponse = await context.fetch(replaceExtension(context?.url || '', 'dbf'));
42
- if (dbfResponse.ok) {
43
- // @ts-ignore context must be defined
44
- propertyIterable = await context.parseInBatches(dbfResponse, DBFLoader, {
45
- ...options,
46
- dbf: {encoding: cpg || 'latin1'}
47
- });
44
+ const dbfResponse = await context?.fetch(replaceExtension(context?.url || '', 'dbf'));
45
+ if (dbfResponse?.ok) {
46
+ propertyIterable = await parseInBatchesFromContext(
47
+ dbfResponse as any,
48
+ DBFLoader,
49
+ {
50
+ ...options,
51
+ dbf: {encoding: cpg || 'latin1'}
52
+ },
53
+ context!
54
+ );
48
55
  }
49
56
 
50
57
  // When `options.metadata` is `true`, there's an extra initial `metadata`
@@ -113,19 +120,21 @@ export async function parseShapefile(
113
120
  const {shx, cpg, prj} = await loadShapefileSidecarFiles(options, context);
114
121
 
115
122
  // parse geometries
116
- // @ts-ignore context must be defined
117
- const {header, geometries} = await context.parse(arrayBuffer, SHPLoader, options); // {shp: shx}
123
+ const {header, geometries} = await parseFromContext(arrayBuffer, SHPLoader, options, context!); // {shp: shx}
118
124
 
119
125
  const geojsonGeometries = parseGeometries(geometries);
120
126
 
121
127
  // parse properties
122
128
  let properties = [];
123
129
 
124
- // @ts-ignore context must be defined
125
- const dbfResponse = await context.fetch(replaceExtension(context.url, 'dbf'));
126
- if (dbfResponse.ok) {
127
- // @ts-ignore context must be defined
128
- properties = await context.parse(dbfResponse, DBFLoader, {dbf: {encoding: cpg || 'latin1'}});
130
+ const dbfResponse = await context?.fetch(replaceExtension(context?.url!, 'dbf'));
131
+ if (dbfResponse?.ok) {
132
+ properties = await parseFromContext(
133
+ dbfResponse as any,
134
+ DBFLoader,
135
+ {dbf: {encoding: cpg || 'latin1'}},
136
+ context!
137
+ );
129
138
  }
130
139
 
131
140
  let features = joinProperties(geojsonGeometries, properties);
@@ -1,4 +1,4 @@
1
- import type {LoaderWithParser} from '@loaders.gl/loader-utils';
1
+ import type {LoaderOptions, LoaderWithParser} from '@loaders.gl/loader-utils';
2
2
  import {SHP_MAGIC_NUMBER} from './shp-loader';
3
3
  import {parseShapefile, parseShapefileInBatches} from './lib/parsers/parse-shapefile';
4
4
 
@@ -10,7 +10,7 @@ const VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';
10
10
  * Shapefile loader
11
11
  * @note Shapefile is multifile format and requires providing additional files
12
12
  */
13
- export const ShapefileLoader = {
13
+ export const ShapefileLoader: LoaderWithParser<any, any, LoaderOptions> = {
14
14
  name: 'Shapefile',
15
15
  id: 'shapefile',
16
16
  module: 'shapefile',
@@ -28,5 +28,3 @@ export const ShapefileLoader = {
28
28
  parse: parseShapefile,
29
29
  parseInBatches: parseShapefileInBatches
30
30
  };
31
-
32
- export const _typecheckShapefileLoader: LoaderWithParser = ShapefileLoader;