@map-colonies/mc-utils 1.0.1 → 1.2.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 +42 -0
- package/README.md +67 -65
- package/dist/communication/http/httpClient.d.ts +24 -24
- package/dist/communication/http/httpClient.d.ts.map +1 -1
- package/dist/communication/http/httpClient.js +329 -315
- 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 -4
- package/dist/geo/bboxUtils.d.ts.map +1 -1
- package/dist/geo/bboxUtils.js +84 -42
- package/dist/geo/bboxUtils.js.map +1 -1
- package/dist/geo/geoConvertor.d.ts +18 -4
- package/dist/geo/geoConvertor.d.ts.map +1 -1
- package/dist/geo/geoConvertor.js +51 -27
- package/dist/geo/geoConvertor.js.map +1 -1
- package/dist/geo/geoHash.d.ts +24 -6
- package/dist/geo/geoHash.d.ts.map +1 -1
- package/dist/geo/geoHash.js +242 -224
- package/dist/geo/geoHash.js.map +1 -1
- package/dist/geo/index.d.ts +5 -4
- package/dist/geo/index.d.ts.map +1 -1
- package/dist/geo/index.js +17 -16
- package/dist/geo/index.js.map +1 -1
- package/dist/geo/tileRanger.d.ts +40 -0
- package/dist/geo/tileRanger.d.ts.map +1 -0
- package/dist/geo/tileRanger.js +255 -0
- package/dist/geo/tileRanger.js.map +1 -0
- package/dist/geo/tiles.d.ts +32 -2
- package/dist/geo/tiles.d.ts.map +1 -1
- package/dist/geo/tiles.js +65 -14
- package/dist/geo/tiles.js.map +1 -1
- package/dist/geo/tilesGenerator.d.ts +3 -0
- package/dist/geo/tilesGenerator.d.ts.map +1 -0
- package/dist/geo/tilesGenerator.js +95 -0
- package/dist/geo/tilesGenerator.js.map +1 -0
- package/dist/index.d.ts +3 -3
- package/dist/index.js +15 -15
- package/dist/models/enums/geo/index.d.ts +2 -0
- package/dist/models/enums/geo/index.d.ts.map +1 -0
- package/dist/models/enums/geo/index.js +14 -0
- package/dist/models/enums/geo/index.js.map +1 -0
- package/dist/models/enums/geo/tileOrigin.d.ts +8 -0
- package/dist/models/enums/geo/tileOrigin.d.ts.map +1 -0
- package/dist/models/enums/geo/tileOrigin.js +12 -0
- package/dist/models/enums/geo/tileOrigin.js.map +1 -0
- package/dist/models/enums/index.d.ts +2 -0
- package/dist/models/enums/index.d.ts.map +1 -0
- package/dist/models/enums/index.js +14 -0
- package/dist/models/enums/index.js.map +1 -0
- package/dist/models/index.d.ts +2 -1
- package/dist/models/index.d.ts.map +1 -1
- package/dist/models/index.js +14 -13
- package/dist/models/index.js.map +1 -1
- package/dist/models/interfaces/geo/iPoint.d.ts +7 -4
- package/dist/models/interfaces/geo/iPoint.d.ts.map +1 -1
- package/dist/models/interfaces/geo/iPoint.js +2 -2
- package/dist/models/interfaces/geo/iTile.d.ts +15 -5
- package/dist/models/interfaces/geo/iTile.d.ts.map +1 -1
- 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.d.ts.map +1 -1
- package/dist/models/interfaces/index.js +14 -14
- package/dist/models/interfaces/index.js.map +1 -1
- package/package.json +76 -76
package/dist/geo/geoHash.js
CHANGED
|
@@ -1,225 +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
|
|
64
|
-
var
|
|
65
|
-
var
|
|
66
|
-
var
|
|
67
|
-
|
|
68
|
-
var
|
|
69
|
-
var
|
|
70
|
-
var
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
var
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
return [
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
_b.
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
case
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
var
|
|
138
|
-
|
|
139
|
-
var
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
_b.label =
|
|
186
|
-
case
|
|
187
|
-
if (
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
y
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
return [3 /*break*/,
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
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;
|
|
225
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,
|
|
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,5 +1,6 @@
|
|
|
1
|
-
export * from './bboxUtils';
|
|
2
|
-
export * from './geoConvertor';
|
|
3
|
-
export * from './geoHash';
|
|
4
|
-
export * from './tiles';
|
|
1
|
+
export * from './bboxUtils';
|
|
2
|
+
export * from './geoConvertor';
|
|
3
|
+
export * from './geoHash';
|
|
4
|
+
export * from './tiles';
|
|
5
|
+
export * from './tileRanger';
|
|
5
6
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/geo/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/geo/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/geo/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC;AACxB,cAAc,cAAc,CAAC"}
|
package/dist/geo/index.js
CHANGED
|
@@ -1,17 +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);
|
|
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);
|
|
17
18
|
//# sourceMappingURL=index.js.map
|
package/dist/geo/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/geo/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,8CAA4B;AAC5B,iDAA+B;AAC/B,4CAA0B;AAC1B,0CAAwB"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/geo/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,8CAA4B;AAC5B,iDAA+B;AAC/B,4CAA0B;AAC1B,0CAAwB;AACxB,+CAA6B"}
|
|
@@ -0,0 +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
|
+
}
|
|
40
|
+
//# sourceMappingURL=tileRanger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tileRanger.d.ts","sourceRoot":"","sources":["../../src/geo/tileRanger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,mCAAmC,CAAC;AAC3D,OAAO,EAA0D,OAAO,EAAa,YAAY,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAC/H,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAkBnE;;GAEG;AACH,qBAAa,UAAU;IACrB;;;;;OAKG;IACI,WAAW,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,GAAG,UAAU;IA4BzD;;;;;OAKG;IACK,eAAe,CAAC,SAAS,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,GAAG,YAAY,CAAC,EAAE,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC,UAAU,CAAC;IAalH;;;;OAIG;IACI,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC,KAAK,CAAC;IAClE;;;;OAIG;IACI,aAAa,CAAC,SAAS,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,GAAG,YAAY,CAAC,EAAE,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC,KAAK,CAAC;IAW1G,OAAO,CAAE,cAAc;IA8BvB,OAAO,CAAE,YAAY;IAiBrB,OAAO,CAAC,gBAAgB;IASxB,OAAO,CAAC,QAAQ,CAAC,yBAAyB,CAgBxC;IAEF,OAAO,CAAC,MAAM;CAKf"}
|