@map-colonies/mc-utils 1.2.0 → 1.3.0
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.
- package/CHANGELOG.md +39 -32
- package/README.md +67 -67
- package/dist/communication/http/httpClient.d.ts +25 -24
- package/dist/communication/http/httpClient.d.ts.map +1 -1
- package/dist/communication/http/httpClient.js +341 -329
- package/dist/communication/http/httpClient.js.map +1 -1
- package/dist/communication/http/index.d.ts +1 -1
- package/dist/communication/http/index.js +13 -13
- package/dist/communication/index.d.ts +1 -1
- package/dist/communication/index.js +13 -13
- package/dist/geo/bboxUtils.d.ts +23 -23
- package/dist/geo/bboxUtils.js +84 -84
- package/dist/geo/bboxUtils.js.map +1 -1
- package/dist/geo/geoConvertor.d.ts +18 -18
- package/dist/geo/geoConvertor.js +51 -51
- package/dist/geo/geoConvertor.js.map +1 -1
- package/dist/geo/geoHash.d.ts +24 -24
- package/dist/geo/geoHash.js +242 -242
- package/dist/geo/geoHash.js.map +1 -1
- package/dist/geo/index.d.ts +5 -5
- package/dist/geo/index.js +17 -17
- package/dist/geo/tileRanger.d.ts +39 -39
- package/dist/geo/tileRanger.js +254 -254
- package/dist/geo/tileRanger.js.map +1 -1
- package/dist/geo/tiles.d.ts +32 -32
- package/dist/geo/tiles.js +65 -65
- package/dist/geo/tiles.js.map +1 -1
- package/dist/geo/tilesGenerator.d.ts +2 -2
- package/dist/geo/tilesGenerator.js +94 -94
- package/dist/index.d.ts +3 -3
- package/dist/index.js +15 -15
- package/dist/models/enums/geo/index.d.ts +1 -1
- package/dist/models/enums/geo/index.js +13 -13
- package/dist/models/enums/geo/tileOrigin.d.ts +7 -7
- package/dist/models/enums/geo/tileOrigin.js +11 -11
- package/dist/models/enums/index.d.ts +1 -1
- package/dist/models/enums/index.js +13 -13
- package/dist/models/index.d.ts +2 -2
- package/dist/models/index.js +14 -14
- package/dist/models/interfaces/geo/iPoint.d.ts +7 -7
- package/dist/models/interfaces/geo/iPoint.js +2 -2
- package/dist/models/interfaces/geo/iTile.d.ts +15 -15
- package/dist/models/interfaces/geo/iTile.js +2 -2
- package/dist/models/interfaces/geo/index.d.ts +2 -2
- package/dist/models/interfaces/geo/index.js +14 -14
- package/dist/models/interfaces/iLogger.d.ts +6 -6
- package/dist/models/interfaces/iLogger.js +2 -2
- package/dist/models/interfaces/index.d.ts +2 -2
- package/dist/models/interfaces/index.js +14 -14
- package/package.json +76 -76
package/dist/geo/geoHash.js
CHANGED
|
@@ -1,243 +1,243 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
-
}) : (function(o, m, k, k2) {
|
|
6
|
-
if (k2 === undefined) k2 = k;
|
|
7
|
-
o[k2] = m[k];
|
|
8
|
-
}));
|
|
9
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
-
}) : function(o, v) {
|
|
12
|
-
o["default"] = v;
|
|
13
|
-
});
|
|
14
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
-
if (mod && mod.__esModule) return mod;
|
|
16
|
-
var result = {};
|
|
17
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
-
__setModuleDefault(result, mod);
|
|
19
|
-
return result;
|
|
20
|
-
};
|
|
21
|
-
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
22
|
-
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
23
|
-
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
24
|
-
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
25
|
-
function step(op) {
|
|
26
|
-
if (f) throw new TypeError("Generator is already executing.");
|
|
27
|
-
while (_) try {
|
|
28
|
-
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
29
|
-
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
30
|
-
switch (op[0]) {
|
|
31
|
-
case 0: case 1: t = op; break;
|
|
32
|
-
case 4: _.label++; return { value: op[1], done: false };
|
|
33
|
-
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
34
|
-
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
35
|
-
default:
|
|
36
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
37
|
-
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
38
|
-
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
39
|
-
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
40
|
-
if (t[2]) _.ops.pop();
|
|
41
|
-
_.trys.pop(); continue;
|
|
42
|
-
}
|
|
43
|
-
op = body.call(thisArg, _);
|
|
44
|
-
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
45
|
-
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
|
-
var __values = (this && this.__values) || function(o) {
|
|
49
|
-
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
50
|
-
if (m) return m.call(o);
|
|
51
|
-
if (o && typeof o.length === "number") return {
|
|
52
|
-
next: function () {
|
|
53
|
-
if (o && i >= o.length) o = void 0;
|
|
54
|
-
return { value: o && o[i++], done: !o };
|
|
55
|
-
}
|
|
56
|
-
};
|
|
57
|
-
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
58
|
-
};
|
|
59
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
60
|
-
exports.tileGenerator = exports.createGeoHashGenerator = exports.decodeGeoHash = void 0;
|
|
61
|
-
var turf_1 = require("@turf/turf");
|
|
62
|
-
var ngeohash = __importStar(require("ngeohash"));
|
|
63
|
-
var tileOrigin_1 = require("../models/enums/geo/tileOrigin");
|
|
64
|
-
var geoConvertor_1 = require("./geoConvertor");
|
|
65
|
-
var bboxUtils_1 = require("./bboxUtils");
|
|
66
|
-
var MAX_STANDARD_ZOOM = 21;
|
|
67
|
-
var bboxIntersection = function (bbox1, bbox2) {
|
|
68
|
-
var minLon = Math.max(bbox1[0], bbox2[0]);
|
|
69
|
-
var minLat = Math.max(bbox1[1], bbox2[1]);
|
|
70
|
-
var maxLon = Math.min(bbox1[2], bbox2[2]);
|
|
71
|
-
var maxLat = Math.min(bbox1[3], bbox2[3]);
|
|
72
|
-
return [minLon, minLat, maxLon, maxLat];
|
|
73
|
-
};
|
|
74
|
-
var isSubHash = function (hash, parent) {
|
|
75
|
-
return hash.startsWith(parent);
|
|
76
|
-
};
|
|
77
|
-
function geoHash(precision, maxPrecision, polygon, bbox, parentHash) {
|
|
78
|
-
var hashes, hashes_1, hashes_1_1, hash, hashBbox, hashPoly, intersection, intArea, hashArea, subBbox, e_1_1;
|
|
79
|
-
var e_1, _a;
|
|
80
|
-
if (parentHash === void 0) { parentHash = ''; }
|
|
81
|
-
return __generator(this, function (_b) {
|
|
82
|
-
switch (_b.label) {
|
|
83
|
-
case 0:
|
|
84
|
-
hashes = ngeohash.bboxes(bbox[1], bbox[0], bbox[3], bbox[2], precision);
|
|
85
|
-
if (!(hashes.length > 0)) return [3 /*break*/, 10];
|
|
86
|
-
_b.label = 1;
|
|
87
|
-
case 1:
|
|
88
|
-
_b.trys.push([1, 8, 9, 10]);
|
|
89
|
-
hashes_1 = __values(hashes), hashes_1_1 = hashes_1.next();
|
|
90
|
-
_b.label = 2;
|
|
91
|
-
case 2:
|
|
92
|
-
if (!!hashes_1_1.done) return [3 /*break*/, 7];
|
|
93
|
-
hash = hashes_1_1.value;
|
|
94
|
-
hashBbox = exports.decodeGeoHash(hash);
|
|
95
|
-
hashPoly = turf_1.bboxPolygon(hashBbox);
|
|
96
|
-
intersection = turf_1.intersect(polygon, hashPoly);
|
|
97
|
-
if (intersection === null || !isSubHash(hash, parentHash)) {
|
|
98
|
-
return [3 /*break*/, 6];
|
|
99
|
-
}
|
|
100
|
-
intArea = turf_1.area(intersection);
|
|
101
|
-
hashArea = turf_1.area(hashPoly);
|
|
102
|
-
if (!(intArea == hashArea || precision == maxPrecision)) return [3 /*break*/, 4];
|
|
103
|
-
return [4 /*yield*/, hash];
|
|
104
|
-
case 3:
|
|
105
|
-
_b.sent();
|
|
106
|
-
return [3 /*break*/, 6];
|
|
107
|
-
case 4:
|
|
108
|
-
subBbox = bboxIntersection(hashBbox, bbox);
|
|
109
|
-
return [5 /*yield**/, __values(geoHash(precision + 1, maxPrecision, polygon, subBbox, hash))];
|
|
110
|
-
case 5:
|
|
111
|
-
_b.sent();
|
|
112
|
-
_b.label = 6;
|
|
113
|
-
case 6:
|
|
114
|
-
hashes_1_1 = hashes_1.next();
|
|
115
|
-
return [3 /*break*/, 2];
|
|
116
|
-
case 7: return [3 /*break*/, 10];
|
|
117
|
-
case 8:
|
|
118
|
-
e_1_1 = _b.sent();
|
|
119
|
-
e_1 = { error: e_1_1 };
|
|
120
|
-
return [3 /*break*/, 10];
|
|
121
|
-
case 9:
|
|
122
|
-
try {
|
|
123
|
-
if (hashes_1_1 && !hashes_1_1.done && (_a = hashes_1.return)) _a.call(hashes_1);
|
|
124
|
-
}
|
|
125
|
-
finally { if (e_1) throw e_1.error; }
|
|
126
|
-
return [7 /*endfinally*/];
|
|
127
|
-
case 10: return [2 /*return*/];
|
|
128
|
-
}
|
|
129
|
-
});
|
|
130
|
-
}
|
|
131
|
-
/**
|
|
132
|
-
* converts geohash string to its bbox in wgs84 degrees
|
|
133
|
-
* @param geohash geohash string
|
|
134
|
-
* @returns bbox of the supplied geohash
|
|
135
|
-
*/
|
|
136
|
-
var decodeGeoHash = function (geohash) {
|
|
137
|
-
var bboxFromGeohash = ngeohash.decode_bbox(geohash);
|
|
138
|
-
// ngeohash.decode_bbox gives a lat-lon array. we change it to lon-lat so @turf can use it.
|
|
139
|
-
var lonLatBbox = [bboxFromGeohash[1], bboxFromGeohash[0], bboxFromGeohash[3], bboxFromGeohash[2]];
|
|
140
|
-
return lonLatBbox;
|
|
141
|
-
};
|
|
142
|
-
exports.decodeGeoHash = decodeGeoHash;
|
|
143
|
-
/**
|
|
144
|
-
* generates optimized geohash iterator for given polygon and target zoom level
|
|
145
|
-
* @param polygon polygon to cover with geohashes
|
|
146
|
-
* @param maxTileZoom target zoom level
|
|
147
|
-
* @returns generator that yields the matching geohashes
|
|
148
|
-
*/
|
|
149
|
-
var createGeoHashGenerator = function (polygon, maxTileZoom) {
|
|
150
|
-
if (maxTileZoom === void 0) { maxTileZoom = MAX_STANDARD_ZOOM; }
|
|
151
|
-
var bbox = turf_1.bbox(polygon);
|
|
152
|
-
bbox = bboxUtils_1.snapBBoxToTileGrid(bbox, maxTileZoom);
|
|
153
|
-
//at this precision ea geo hash is a tile or smaller
|
|
154
|
-
/* eslint-disable @typescript-eslint/no-magic-numbers */
|
|
155
|
-
var zoomPrecision = Math.floor((2 / 5) * (maxTileZoom + 1));
|
|
156
|
-
var precisionMod = maxTileZoom % 5;
|
|
157
|
-
if (precisionMod > 0 && precisionMod <= 3) {
|
|
158
|
-
zoomPrecision++;
|
|
159
|
-
}
|
|
160
|
-
else if (precisionMod > 3) {
|
|
161
|
-
zoomPrecision += 2;
|
|
162
|
-
}
|
|
163
|
-
/* eslint-enable @typescript-eslint/no-magic-numbers */
|
|
164
|
-
return geoHash(1, zoomPrecision, polygon, bbox);
|
|
165
|
-
};
|
|
166
|
-
exports.createGeoHashGenerator = createGeoHashGenerator;
|
|
167
|
-
/**
|
|
168
|
-
* generate all tiles in supplied polygon
|
|
169
|
-
* @param polygon polygon to cover with tiles
|
|
170
|
-
* @param tileZoom target tiles zoom level
|
|
171
|
-
* @param origin target tiles grid origin location (default ll)
|
|
172
|
-
*/
|
|
173
|
-
function tileGenerator(polygon, tileZoom, origin) {
|
|
174
|
-
var hashGen, hashGen_1, hashGen_1_1, hash, bbox, minTile, maxTile, minX, maxX, minY, maxY, x, y, e_2_1;
|
|
175
|
-
var e_2, _a;
|
|
176
|
-
if (origin === void 0) { origin = tileOrigin_1.TileOrigin.LOWER_LEFT; }
|
|
177
|
-
return __generator(this, function (_b) {
|
|
178
|
-
switch (_b.label) {
|
|
179
|
-
case 0:
|
|
180
|
-
hashGen = exports.createGeoHashGenerator(polygon, tileZoom);
|
|
181
|
-
_b.label = 1;
|
|
182
|
-
case 1:
|
|
183
|
-
_b.trys.push([1, 10, 11, 12]);
|
|
184
|
-
hashGen_1 = __values(hashGen), hashGen_1_1 = hashGen_1.next();
|
|
185
|
-
_b.label = 2;
|
|
186
|
-
case 2:
|
|
187
|
-
if (!!hashGen_1_1.done) return [3 /*break*/, 9];
|
|
188
|
-
hash = hashGen_1_1.value;
|
|
189
|
-
bbox = exports.decodeGeoHash(hash);
|
|
190
|
-
minTile = geoConvertor_1.degreesToTile({
|
|
191
|
-
longitude: bbox[0],
|
|
192
|
-
latitude: bbox[1],
|
|
193
|
-
}, tileZoom, origin);
|
|
194
|
-
maxTile = geoConvertor_1.degreesToTile({
|
|
195
|
-
longitude: bbox[2],
|
|
196
|
-
latitude: bbox[3],
|
|
197
|
-
}, tileZoom, origin);
|
|
198
|
-
minX = Math.min(minTile.x, maxTile.x);
|
|
199
|
-
maxX = minTile.x + maxTile.x - minX;
|
|
200
|
-
minY = Math.min(minTile.y, maxTile.y);
|
|
201
|
-
maxY = minTile.y + maxTile.y - minY;
|
|
202
|
-
x = minX;
|
|
203
|
-
_b.label = 3;
|
|
204
|
-
case 3:
|
|
205
|
-
if (!(x < maxX)) return [3 /*break*/, 8];
|
|
206
|
-
y = minY;
|
|
207
|
-
_b.label = 4;
|
|
208
|
-
case 4:
|
|
209
|
-
if (!(y < maxY)) return [3 /*break*/, 7];
|
|
210
|
-
return [4 /*yield*/, {
|
|
211
|
-
x: x,
|
|
212
|
-
y: y,
|
|
213
|
-
zoom: tileZoom,
|
|
214
|
-
}];
|
|
215
|
-
case 5:
|
|
216
|
-
_b.sent();
|
|
217
|
-
_b.label = 6;
|
|
218
|
-
case 6:
|
|
219
|
-
y++;
|
|
220
|
-
return [3 /*break*/, 4];
|
|
221
|
-
case 7:
|
|
222
|
-
x++;
|
|
223
|
-
return [3 /*break*/, 3];
|
|
224
|
-
case 8:
|
|
225
|
-
hashGen_1_1 = hashGen_1.next();
|
|
226
|
-
return [3 /*break*/, 2];
|
|
227
|
-
case 9: return [3 /*break*/, 12];
|
|
228
|
-
case 10:
|
|
229
|
-
e_2_1 = _b.sent();
|
|
230
|
-
e_2 = { error: e_2_1 };
|
|
231
|
-
return [3 /*break*/, 12];
|
|
232
|
-
case 11:
|
|
233
|
-
try {
|
|
234
|
-
if (hashGen_1_1 && !hashGen_1_1.done && (_a = hashGen_1.return)) _a.call(hashGen_1);
|
|
235
|
-
}
|
|
236
|
-
finally { if (e_2) throw e_2.error; }
|
|
237
|
-
return [7 /*endfinally*/];
|
|
238
|
-
case 12: return [2 /*return*/];
|
|
239
|
-
}
|
|
240
|
-
});
|
|
241
|
-
}
|
|
242
|
-
exports.tileGenerator = tileGenerator;
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
+
}) : function(o, v) {
|
|
12
|
+
o["default"] = v;
|
|
13
|
+
});
|
|
14
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
+
if (mod && mod.__esModule) return mod;
|
|
16
|
+
var result = {};
|
|
17
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
+
__setModuleDefault(result, mod);
|
|
19
|
+
return result;
|
|
20
|
+
};
|
|
21
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
22
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
23
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
24
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
25
|
+
function step(op) {
|
|
26
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
27
|
+
while (_) try {
|
|
28
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
29
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
30
|
+
switch (op[0]) {
|
|
31
|
+
case 0: case 1: t = op; break;
|
|
32
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
33
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
34
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
35
|
+
default:
|
|
36
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
37
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
38
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
39
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
40
|
+
if (t[2]) _.ops.pop();
|
|
41
|
+
_.trys.pop(); continue;
|
|
42
|
+
}
|
|
43
|
+
op = body.call(thisArg, _);
|
|
44
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
45
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
var __values = (this && this.__values) || function(o) {
|
|
49
|
+
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
50
|
+
if (m) return m.call(o);
|
|
51
|
+
if (o && typeof o.length === "number") return {
|
|
52
|
+
next: function () {
|
|
53
|
+
if (o && i >= o.length) o = void 0;
|
|
54
|
+
return { value: o && o[i++], done: !o };
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
58
|
+
};
|
|
59
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
60
|
+
exports.tileGenerator = exports.createGeoHashGenerator = exports.decodeGeoHash = void 0;
|
|
61
|
+
var turf_1 = require("@turf/turf");
|
|
62
|
+
var ngeohash = __importStar(require("ngeohash"));
|
|
63
|
+
var tileOrigin_1 = require("../models/enums/geo/tileOrigin");
|
|
64
|
+
var geoConvertor_1 = require("./geoConvertor");
|
|
65
|
+
var bboxUtils_1 = require("./bboxUtils");
|
|
66
|
+
var MAX_STANDARD_ZOOM = 21;
|
|
67
|
+
var bboxIntersection = function (bbox1, bbox2) {
|
|
68
|
+
var minLon = Math.max(bbox1[0], bbox2[0]);
|
|
69
|
+
var minLat = Math.max(bbox1[1], bbox2[1]);
|
|
70
|
+
var maxLon = Math.min(bbox1[2], bbox2[2]);
|
|
71
|
+
var maxLat = Math.min(bbox1[3], bbox2[3]);
|
|
72
|
+
return [minLon, minLat, maxLon, maxLat];
|
|
73
|
+
};
|
|
74
|
+
var isSubHash = function (hash, parent) {
|
|
75
|
+
return hash.startsWith(parent);
|
|
76
|
+
};
|
|
77
|
+
function geoHash(precision, maxPrecision, polygon, bbox, parentHash) {
|
|
78
|
+
var hashes, hashes_1, hashes_1_1, hash, hashBbox, hashPoly, intersection, intArea, hashArea, subBbox, e_1_1;
|
|
79
|
+
var e_1, _a;
|
|
80
|
+
if (parentHash === void 0) { parentHash = ''; }
|
|
81
|
+
return __generator(this, function (_b) {
|
|
82
|
+
switch (_b.label) {
|
|
83
|
+
case 0:
|
|
84
|
+
hashes = ngeohash.bboxes(bbox[1], bbox[0], bbox[3], bbox[2], precision);
|
|
85
|
+
if (!(hashes.length > 0)) return [3 /*break*/, 10];
|
|
86
|
+
_b.label = 1;
|
|
87
|
+
case 1:
|
|
88
|
+
_b.trys.push([1, 8, 9, 10]);
|
|
89
|
+
hashes_1 = __values(hashes), hashes_1_1 = hashes_1.next();
|
|
90
|
+
_b.label = 2;
|
|
91
|
+
case 2:
|
|
92
|
+
if (!!hashes_1_1.done) return [3 /*break*/, 7];
|
|
93
|
+
hash = hashes_1_1.value;
|
|
94
|
+
hashBbox = (0, exports.decodeGeoHash)(hash);
|
|
95
|
+
hashPoly = (0, turf_1.bboxPolygon)(hashBbox);
|
|
96
|
+
intersection = (0, turf_1.intersect)(polygon, hashPoly);
|
|
97
|
+
if (intersection === null || !isSubHash(hash, parentHash)) {
|
|
98
|
+
return [3 /*break*/, 6];
|
|
99
|
+
}
|
|
100
|
+
intArea = (0, turf_1.area)(intersection);
|
|
101
|
+
hashArea = (0, turf_1.area)(hashPoly);
|
|
102
|
+
if (!(intArea == hashArea || precision == maxPrecision)) return [3 /*break*/, 4];
|
|
103
|
+
return [4 /*yield*/, hash];
|
|
104
|
+
case 3:
|
|
105
|
+
_b.sent();
|
|
106
|
+
return [3 /*break*/, 6];
|
|
107
|
+
case 4:
|
|
108
|
+
subBbox = bboxIntersection(hashBbox, bbox);
|
|
109
|
+
return [5 /*yield**/, __values(geoHash(precision + 1, maxPrecision, polygon, subBbox, hash))];
|
|
110
|
+
case 5:
|
|
111
|
+
_b.sent();
|
|
112
|
+
_b.label = 6;
|
|
113
|
+
case 6:
|
|
114
|
+
hashes_1_1 = hashes_1.next();
|
|
115
|
+
return [3 /*break*/, 2];
|
|
116
|
+
case 7: return [3 /*break*/, 10];
|
|
117
|
+
case 8:
|
|
118
|
+
e_1_1 = _b.sent();
|
|
119
|
+
e_1 = { error: e_1_1 };
|
|
120
|
+
return [3 /*break*/, 10];
|
|
121
|
+
case 9:
|
|
122
|
+
try {
|
|
123
|
+
if (hashes_1_1 && !hashes_1_1.done && (_a = hashes_1.return)) _a.call(hashes_1);
|
|
124
|
+
}
|
|
125
|
+
finally { if (e_1) throw e_1.error; }
|
|
126
|
+
return [7 /*endfinally*/];
|
|
127
|
+
case 10: return [2 /*return*/];
|
|
128
|
+
}
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* converts geohash string to its bbox in wgs84 degrees
|
|
133
|
+
* @param geohash geohash string
|
|
134
|
+
* @returns bbox of the supplied geohash
|
|
135
|
+
*/
|
|
136
|
+
var decodeGeoHash = function (geohash) {
|
|
137
|
+
var bboxFromGeohash = ngeohash.decode_bbox(geohash);
|
|
138
|
+
// ngeohash.decode_bbox gives a lat-lon array. we change it to lon-lat so @turf can use it.
|
|
139
|
+
var lonLatBbox = [bboxFromGeohash[1], bboxFromGeohash[0], bboxFromGeohash[3], bboxFromGeohash[2]];
|
|
140
|
+
return lonLatBbox;
|
|
141
|
+
};
|
|
142
|
+
exports.decodeGeoHash = decodeGeoHash;
|
|
143
|
+
/**
|
|
144
|
+
* generates optimized geohash iterator for given polygon and target zoom level
|
|
145
|
+
* @param polygon polygon to cover with geohashes
|
|
146
|
+
* @param maxTileZoom target zoom level
|
|
147
|
+
* @returns generator that yields the matching geohashes
|
|
148
|
+
*/
|
|
149
|
+
var createGeoHashGenerator = function (polygon, maxTileZoom) {
|
|
150
|
+
if (maxTileZoom === void 0) { maxTileZoom = MAX_STANDARD_ZOOM; }
|
|
151
|
+
var bbox = (0, turf_1.bbox)(polygon);
|
|
152
|
+
bbox = (0, bboxUtils_1.snapBBoxToTileGrid)(bbox, maxTileZoom);
|
|
153
|
+
//at this precision ea geo hash is a tile or smaller
|
|
154
|
+
/* eslint-disable @typescript-eslint/no-magic-numbers */
|
|
155
|
+
var zoomPrecision = Math.floor((2 / 5) * (maxTileZoom + 1));
|
|
156
|
+
var precisionMod = maxTileZoom % 5;
|
|
157
|
+
if (precisionMod > 0 && precisionMod <= 3) {
|
|
158
|
+
zoomPrecision++;
|
|
159
|
+
}
|
|
160
|
+
else if (precisionMod > 3) {
|
|
161
|
+
zoomPrecision += 2;
|
|
162
|
+
}
|
|
163
|
+
/* eslint-enable @typescript-eslint/no-magic-numbers */
|
|
164
|
+
return geoHash(1, zoomPrecision, polygon, bbox);
|
|
165
|
+
};
|
|
166
|
+
exports.createGeoHashGenerator = createGeoHashGenerator;
|
|
167
|
+
/**
|
|
168
|
+
* generate all tiles in supplied polygon
|
|
169
|
+
* @param polygon polygon to cover with tiles
|
|
170
|
+
* @param tileZoom target tiles zoom level
|
|
171
|
+
* @param origin target tiles grid origin location (default ll)
|
|
172
|
+
*/
|
|
173
|
+
function tileGenerator(polygon, tileZoom, origin) {
|
|
174
|
+
var hashGen, hashGen_1, hashGen_1_1, hash, bbox, minTile, maxTile, minX, maxX, minY, maxY, x, y, e_2_1;
|
|
175
|
+
var e_2, _a;
|
|
176
|
+
if (origin === void 0) { origin = tileOrigin_1.TileOrigin.LOWER_LEFT; }
|
|
177
|
+
return __generator(this, function (_b) {
|
|
178
|
+
switch (_b.label) {
|
|
179
|
+
case 0:
|
|
180
|
+
hashGen = (0, exports.createGeoHashGenerator)(polygon, tileZoom);
|
|
181
|
+
_b.label = 1;
|
|
182
|
+
case 1:
|
|
183
|
+
_b.trys.push([1, 10, 11, 12]);
|
|
184
|
+
hashGen_1 = __values(hashGen), hashGen_1_1 = hashGen_1.next();
|
|
185
|
+
_b.label = 2;
|
|
186
|
+
case 2:
|
|
187
|
+
if (!!hashGen_1_1.done) return [3 /*break*/, 9];
|
|
188
|
+
hash = hashGen_1_1.value;
|
|
189
|
+
bbox = (0, exports.decodeGeoHash)(hash);
|
|
190
|
+
minTile = (0, geoConvertor_1.degreesToTile)({
|
|
191
|
+
longitude: bbox[0],
|
|
192
|
+
latitude: bbox[1],
|
|
193
|
+
}, tileZoom, origin);
|
|
194
|
+
maxTile = (0, geoConvertor_1.degreesToTile)({
|
|
195
|
+
longitude: bbox[2],
|
|
196
|
+
latitude: bbox[3],
|
|
197
|
+
}, tileZoom, origin);
|
|
198
|
+
minX = Math.min(minTile.x, maxTile.x);
|
|
199
|
+
maxX = minTile.x + maxTile.x - minX;
|
|
200
|
+
minY = Math.min(minTile.y, maxTile.y);
|
|
201
|
+
maxY = minTile.y + maxTile.y - minY;
|
|
202
|
+
x = minX;
|
|
203
|
+
_b.label = 3;
|
|
204
|
+
case 3:
|
|
205
|
+
if (!(x < maxX)) return [3 /*break*/, 8];
|
|
206
|
+
y = minY;
|
|
207
|
+
_b.label = 4;
|
|
208
|
+
case 4:
|
|
209
|
+
if (!(y < maxY)) return [3 /*break*/, 7];
|
|
210
|
+
return [4 /*yield*/, {
|
|
211
|
+
x: x,
|
|
212
|
+
y: y,
|
|
213
|
+
zoom: tileZoom,
|
|
214
|
+
}];
|
|
215
|
+
case 5:
|
|
216
|
+
_b.sent();
|
|
217
|
+
_b.label = 6;
|
|
218
|
+
case 6:
|
|
219
|
+
y++;
|
|
220
|
+
return [3 /*break*/, 4];
|
|
221
|
+
case 7:
|
|
222
|
+
x++;
|
|
223
|
+
return [3 /*break*/, 3];
|
|
224
|
+
case 8:
|
|
225
|
+
hashGen_1_1 = hashGen_1.next();
|
|
226
|
+
return [3 /*break*/, 2];
|
|
227
|
+
case 9: return [3 /*break*/, 12];
|
|
228
|
+
case 10:
|
|
229
|
+
e_2_1 = _b.sent();
|
|
230
|
+
e_2 = { error: e_2_1 };
|
|
231
|
+
return [3 /*break*/, 12];
|
|
232
|
+
case 11:
|
|
233
|
+
try {
|
|
234
|
+
if (hashGen_1_1 && !hashGen_1_1.done && (_a = hashGen_1.return)) _a.call(hashGen_1);
|
|
235
|
+
}
|
|
236
|
+
finally { if (e_2) throw e_2.error; }
|
|
237
|
+
return [7 /*endfinally*/];
|
|
238
|
+
case 12: return [2 /*return*/];
|
|
239
|
+
}
|
|
240
|
+
});
|
|
241
|
+
}
|
|
242
|
+
exports.tileGenerator = tileGenerator;
|
|
243
243
|
//# sourceMappingURL=geoHash.js.map
|
package/dist/geo/geoHash.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"geoHash.js","sourceRoot":"","sources":["../../src/geo/geoHash.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mCAAiH;AAEjH,iDAAqC;AAErC,6DAA4D;AAC5D,+CAA+C;AAC/C,yCAAiD;AAEjD,IAAM,iBAAiB,GAAG,EAAE,CAAC;AAE7B,IAAM,gBAAgB,GAAG,UAAC,KAAa,EAAE,KAAa;IACpD,IAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5C,IAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5C,IAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5C,IAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5C,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;AAC1C,CAAC,CAAC;AAEF,IAAM,SAAS,GAAG,UAAC,IAAY,EAAE,MAAc;IAC7C,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AACjC,CAAC,CAAC;AAEF,SAAU,OAAO,CACf,SAAiB,EACjB,YAAoB,EACpB,OAAkD,EAClD,IAAY,EACZ,UAAe;;;IAAf,2BAAA,EAAA,eAAe;;;;gBAGT,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;qBAC1E,CAAA,MAAM,CAAC,MAAM,GAAG,CAAC,CAAA,EAAjB,yBAAiB;;;;gBACA,WAAA,SAAA,MAAM,CAAA;;;;gBAAd,IAAI;gBACP,QAAQ,GAAG,qBAAa,
|
|
1
|
+
{"version":3,"file":"geoHash.js","sourceRoot":"","sources":["../../src/geo/geoHash.ts"],"names":[],"mappings":"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"}
|
package/dist/geo/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export * from './bboxUtils';
|
|
2
|
-
export * from './geoConvertor';
|
|
3
|
-
export * from './geoHash';
|
|
4
|
-
export * from './tiles';
|
|
5
|
-
export * from './tileRanger';
|
|
1
|
+
export * from './bboxUtils';
|
|
2
|
+
export * from './geoConvertor';
|
|
3
|
+
export * from './geoHash';
|
|
4
|
+
export * from './tiles';
|
|
5
|
+
export * from './tileRanger';
|
|
6
6
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/geo/index.js
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
-
}) : (function(o, m, k, k2) {
|
|
6
|
-
if (k2 === undefined) k2 = k;
|
|
7
|
-
o[k2] = m[k];
|
|
8
|
-
}));
|
|
9
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
10
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
|
-
};
|
|
12
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
-
__exportStar(require("./bboxUtils"), exports);
|
|
14
|
-
__exportStar(require("./geoConvertor"), exports);
|
|
15
|
-
__exportStar(require("./geoHash"), exports);
|
|
16
|
-
__exportStar(require("./tiles"), exports);
|
|
17
|
-
__exportStar(require("./tileRanger"), exports);
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
10
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
|
+
};
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
__exportStar(require("./bboxUtils"), exports);
|
|
14
|
+
__exportStar(require("./geoConvertor"), exports);
|
|
15
|
+
__exportStar(require("./geoHash"), exports);
|
|
16
|
+
__exportStar(require("./tiles"), exports);
|
|
17
|
+
__exportStar(require("./tileRanger"), exports);
|
|
18
18
|
//# sourceMappingURL=index.js.map
|
package/dist/geo/tileRanger.d.ts
CHANGED
|
@@ -1,40 +1,40 @@
|
|
|
1
|
-
import { BBox2d } from '@turf/helpers/dist/js/lib/geojson';
|
|
2
|
-
import { Feature, MultiPolygon, Polygon } from '@turf/turf';
|
|
3
|
-
import { ITile, ITileRange } from '../models/interfaces/geo/iTile';
|
|
4
|
-
/**
|
|
5
|
-
* class for generating and decoding tile hashes
|
|
6
|
-
*/
|
|
7
|
-
export declare class TileRanger {
|
|
8
|
-
/**
|
|
9
|
-
* converts tile to tile range of specified zoom level
|
|
10
|
-
* @param tile
|
|
11
|
-
* @param zoom target tile range zoom
|
|
12
|
-
* @returns
|
|
13
|
-
*/
|
|
14
|
-
tileToRange(tile: ITile, zoom: number): ITileRange;
|
|
15
|
-
/**
|
|
16
|
-
* generate tile hashes
|
|
17
|
-
* @param footprint footprint to cover with generated tile hashes
|
|
18
|
-
* @param zoom max hash zoom
|
|
19
|
-
* @returns
|
|
20
|
-
*/
|
|
21
|
-
encodeFootprint(footprint: Polygon | Feature<Polygon | MultiPolygon>, zoom: number): Generator<ITileRange>;
|
|
22
|
-
/**
|
|
23
|
-
* generate tile
|
|
24
|
-
* @param bbox bbox to cover with generated tiles
|
|
25
|
-
* @param zoom target tiles zoom level
|
|
26
|
-
*/
|
|
27
|
-
generateTiles(bbox: BBox2d, zoom: number): Generator<ITile>;
|
|
28
|
-
/**
|
|
29
|
-
* generate tile
|
|
30
|
-
* @param footprint footprint to cover with generated tiles
|
|
31
|
-
* @param zoom target tiles zoom level
|
|
32
|
-
*/
|
|
33
|
-
generateTiles(footprint: Polygon | Feature<Polygon | MultiPolygon>, zoom: number): Generator<ITile>;
|
|
34
|
-
private generateRanges;
|
|
35
|
-
private optimizeHash;
|
|
36
|
-
private generateSubTiles;
|
|
37
|
-
private readonly tileFootprintIntersection;
|
|
38
|
-
private isBbox;
|
|
39
|
-
}
|
|
1
|
+
import { BBox2d } from '@turf/helpers/dist/js/lib/geojson';
|
|
2
|
+
import { Feature, MultiPolygon, Polygon } from '@turf/turf';
|
|
3
|
+
import { ITile, ITileRange } from '../models/interfaces/geo/iTile';
|
|
4
|
+
/**
|
|
5
|
+
* class for generating and decoding tile hashes
|
|
6
|
+
*/
|
|
7
|
+
export declare class TileRanger {
|
|
8
|
+
/**
|
|
9
|
+
* converts tile to tile range of specified zoom level
|
|
10
|
+
* @param tile
|
|
11
|
+
* @param zoom target tile range zoom
|
|
12
|
+
* @returns
|
|
13
|
+
*/
|
|
14
|
+
tileToRange(tile: ITile, zoom: number): ITileRange;
|
|
15
|
+
/**
|
|
16
|
+
* generate tile hashes
|
|
17
|
+
* @param footprint footprint to cover with generated tile hashes
|
|
18
|
+
* @param zoom max hash zoom
|
|
19
|
+
* @returns
|
|
20
|
+
*/
|
|
21
|
+
encodeFootprint(footprint: Polygon | Feature<Polygon | MultiPolygon>, zoom: number): Generator<ITileRange>;
|
|
22
|
+
/**
|
|
23
|
+
* generate tile
|
|
24
|
+
* @param bbox bbox to cover with generated tiles
|
|
25
|
+
* @param zoom target tiles zoom level
|
|
26
|
+
*/
|
|
27
|
+
generateTiles(bbox: BBox2d, zoom: number): Generator<ITile>;
|
|
28
|
+
/**
|
|
29
|
+
* generate tile
|
|
30
|
+
* @param footprint footprint to cover with generated tiles
|
|
31
|
+
* @param zoom target tiles zoom level
|
|
32
|
+
*/
|
|
33
|
+
generateTiles(footprint: Polygon | Feature<Polygon | MultiPolygon>, zoom: number): Generator<ITile>;
|
|
34
|
+
private generateRanges;
|
|
35
|
+
private optimizeHash;
|
|
36
|
+
private generateSubTiles;
|
|
37
|
+
private readonly tileFootprintIntersection;
|
|
38
|
+
private isBbox;
|
|
39
|
+
}
|
|
40
40
|
//# sourceMappingURL=tileRanger.d.ts.map
|