@flowmap.gl/data 8.0.0-alpha.1 → 8.0.0-alpha.13
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/dist/FlowmapAggregateAccessors.d.ts +16 -0
- package/dist/FlowmapAggregateAccessors.d.ts.map +1 -0
- package/dist/FlowmapAggregateAccessors.js +46 -0
- package/dist/FlowmapSelectors.d.ts +188 -0
- package/dist/FlowmapSelectors.d.ts.map +1 -0
- package/dist/FlowmapSelectors.js +863 -0
- package/dist/FlowmapState.d.ts +27 -0
- package/dist/FlowmapState.d.ts.map +1 -0
- package/dist/FlowmapState.js +2 -0
- package/dist/cluster/cluster.d.ts.map +1 -1
- package/dist/cluster/cluster.js +8 -5
- package/dist/colors.d.ts +7 -7
- package/dist/colors.d.ts.map +1 -1
- package/dist/colors.js +55 -20
- package/dist/getViewStateForLocations.d.ts +18 -11
- package/dist/getViewStateForLocations.d.ts.map +1 -1
- package/dist/getViewStateForLocations.js +23 -20
- package/dist/index.d.ts +6 -6
- package/dist/index.js +6 -6
- package/dist/provider/FlowmapDataProvider.d.ts +16 -0
- package/dist/provider/FlowmapDataProvider.d.ts.map +1 -0
- package/dist/provider/FlowmapDataProvider.js +17 -0
- package/dist/provider/LocalFlowmapDataProvider.d.ts +20 -0
- package/dist/provider/LocalFlowmapDataProvider.d.ts.map +1 -0
- package/dist/provider/LocalFlowmapDataProvider.js +98 -0
- package/dist/types.d.ts +6 -4
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +1 -1
- package/dist/util.d.ts +0 -1
- package/dist/util.d.ts.map +1 -1
- package/dist/util.js +1 -4
- package/dist-es5/FlowmapAggregateAccessors.d.ts +16 -0
- package/dist-es5/FlowmapAggregateAccessors.d.ts.map +1 -0
- package/dist-es5/FlowmapAggregateAccessors.js +57 -0
- package/{dist/FlowMapSelectors.d.ts → dist-es5/FlowmapSelectors.d.ts} +55 -49
- package/dist-es5/FlowmapSelectors.d.ts.map +1 -0
- package/dist-es5/FlowmapSelectors.js +1507 -0
- package/{dist/FlowMapState.d.ts → dist-es5/FlowmapState.d.ts} +6 -3
- package/dist-es5/FlowmapState.d.ts.map +1 -0
- package/dist-es5/FlowmapState.js +3 -0
- package/dist-es5/cluster/ClusterIndex.d.ts +42 -0
- package/dist-es5/cluster/ClusterIndex.d.ts.map +1 -0
- package/dist-es5/cluster/ClusterIndex.js +297 -0
- package/dist-es5/cluster/cluster.d.ts +31 -0
- package/dist-es5/cluster/cluster.d.ts.map +1 -0
- package/dist-es5/cluster/cluster.js +266 -0
- package/dist-es5/colors.d.ts +103 -0
- package/dist-es5/colors.d.ts.map +1 -0
- package/dist-es5/colors.js +510 -0
- package/dist-es5/getViewStateForLocations.d.ts +23 -0
- package/dist-es5/getViewStateForLocations.d.ts.map +1 -0
- package/dist-es5/getViewStateForLocations.js +64 -0
- package/dist-es5/index.d.ts +11 -0
- package/dist-es5/index.d.ts.map +1 -0
- package/dist-es5/index.js +28 -0
- package/dist-es5/provider/FlowmapDataProvider.d.ts +16 -0
- package/dist-es5/provider/FlowmapDataProvider.d.ts.map +1 -0
- package/dist-es5/provider/FlowmapDataProvider.js +22 -0
- package/dist-es5/provider/LocalFlowmapDataProvider.d.ts +20 -0
- package/dist-es5/provider/LocalFlowmapDataProvider.d.ts.map +1 -0
- package/dist-es5/provider/LocalFlowmapDataProvider.js +154 -0
- package/dist-es5/time.d.ts +24 -0
- package/dist-es5/time.d.ts.map +1 -0
- package/dist-es5/time.js +168 -0
- package/dist-es5/types.d.ts +118 -0
- package/dist-es5/types.d.ts.map +1 -0
- package/dist-es5/types.js +29 -0
- package/dist-es5/util.d.ts +5 -0
- package/dist-es5/util.d.ts.map +1 -0
- package/dist-es5/util.js +14 -0
- package/package.json +7 -5
- package/src/{FlowMapAggregateAccessors.ts → FlowmapAggregateAccessors.ts} +14 -9
- package/src/{FlowMapSelectors.ts → FlowmapSelectors.ts} +213 -178
- package/src/{FlowMapState.ts → FlowmapState.ts} +5 -2
- package/src/cluster/cluster.ts +7 -4
- package/src/colors.ts +65 -21
- package/src/getViewStateForLocations.ts +41 -35
- package/src/index.ts +6 -6
- package/src/provider/{FlowMapDataProvider.ts → FlowmapDataProvider.ts} +14 -12
- package/src/provider/LocalFlowmapDataProvider.ts +122 -0
- package/src/types.ts +6 -4
- package/src/util.ts +0 -4
- package/tsconfig.es5.json +11 -0
- package/dist/FlowMapAggregateAccessors.d.ts +0 -15
- package/dist/FlowMapAggregateAccessors.d.ts.map +0 -1
- package/dist/FlowMapAggregateAccessors.js +0 -43
- package/dist/FlowMapSelectors.d.ts.map +0 -1
- package/dist/FlowMapSelectors.js +0 -834
- package/dist/FlowMapState.d.ts.map +0 -1
- package/dist/FlowMapState.js +0 -2
- package/dist/provider/FlowMapDataProvider.d.ts +0 -16
- package/dist/provider/FlowMapDataProvider.d.ts.map +0 -1
- package/dist/provider/FlowMapDataProvider.js +0 -17
- package/dist/provider/LocalFlowMapDataProvider.d.ts +0 -20
- package/dist/provider/LocalFlowMapDataProvider.d.ts.map +0 -1
- package/dist/provider/LocalFlowMapDataProvider.js +0 -87
- package/src/provider/LocalFlowMapDataProvider.ts +0 -105
|
@@ -0,0 +1,266 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright 2022 FlowmapBlue
|
|
4
|
+
* Copyright 2018-2020 Teralytics, modified by FlowmapBlue
|
|
5
|
+
*
|
|
6
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
7
|
+
* you may not use this file except in compliance with the License.
|
|
8
|
+
* You may obtain a copy of the License at
|
|
9
|
+
*
|
|
10
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
11
|
+
*
|
|
12
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
13
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
14
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
15
|
+
* See the License for the specific language governing permissions and
|
|
16
|
+
* limitations under the License.
|
|
17
|
+
*
|
|
18
|
+
*/
|
|
19
|
+
var __assign = (this && this.__assign) || function () {
|
|
20
|
+
__assign = Object.assign || function(t) {
|
|
21
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
22
|
+
s = arguments[i];
|
|
23
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
24
|
+
t[p] = s[p];
|
|
25
|
+
}
|
|
26
|
+
return t;
|
|
27
|
+
};
|
|
28
|
+
return __assign.apply(this, arguments);
|
|
29
|
+
};
|
|
30
|
+
var __values = (this && this.__values) || function(o) {
|
|
31
|
+
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
32
|
+
if (m) return m.call(o);
|
|
33
|
+
if (o && typeof o.length === "number") return {
|
|
34
|
+
next: function () {
|
|
35
|
+
if (o && i >= o.length) o = void 0;
|
|
36
|
+
return { value: o && o[i++], done: !o };
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
40
|
+
};
|
|
41
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
42
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
43
|
+
};
|
|
44
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
45
|
+
exports.clusterLocations = exports.isClusterPoint = exports.isLeafPoint = void 0;
|
|
46
|
+
/**
|
|
47
|
+
* The code in this file is a based on https://github.com/mapbox/supercluster
|
|
48
|
+
*/
|
|
49
|
+
// ISC License
|
|
50
|
+
//
|
|
51
|
+
// Copyright (c) 2016, Mapbox
|
|
52
|
+
//
|
|
53
|
+
// Permission to use, copy, modify, and/or distribute this software for any purpose
|
|
54
|
+
// with or without fee is hereby granted, provided that the above copyright notice
|
|
55
|
+
// and this permission notice appear in all copies.
|
|
56
|
+
//
|
|
57
|
+
// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
|
|
58
|
+
// REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
59
|
+
// FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
|
|
60
|
+
// INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS
|
|
61
|
+
// OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
|
|
62
|
+
// TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF
|
|
63
|
+
// THIS SOFTWARE.
|
|
64
|
+
var d3_array_1 = require("d3-array");
|
|
65
|
+
var kdbush_1 = __importDefault(require("kdbush"));
|
|
66
|
+
var defaultOptions = {
|
|
67
|
+
minZoom: 0,
|
|
68
|
+
maxZoom: 16,
|
|
69
|
+
radius: 40,
|
|
70
|
+
extent: 512,
|
|
71
|
+
nodeSize: 64,
|
|
72
|
+
makeClusterName: function (id, numPoints) { return undefined; },
|
|
73
|
+
makeClusterId: function (id) { return "{[".concat(id, "]}"); },
|
|
74
|
+
};
|
|
75
|
+
function isLeafPoint(p) {
|
|
76
|
+
var index = p.index;
|
|
77
|
+
return index != null;
|
|
78
|
+
}
|
|
79
|
+
exports.isLeafPoint = isLeafPoint;
|
|
80
|
+
function isClusterPoint(p) {
|
|
81
|
+
var id = p.id;
|
|
82
|
+
return id != null;
|
|
83
|
+
}
|
|
84
|
+
exports.isClusterPoint = isClusterPoint;
|
|
85
|
+
function clusterLocations(locations, locationAccessors, getLocationWeight, options) {
|
|
86
|
+
var e_1, _a;
|
|
87
|
+
var getLocationLon = locationAccessors.getLocationLon, getLocationLat = locationAccessors.getLocationLat, getLocationId = locationAccessors.getLocationId;
|
|
88
|
+
var opts = __assign(__assign({}, defaultOptions), options);
|
|
89
|
+
var minZoom = opts.minZoom, maxZoom = opts.maxZoom, nodeSize = opts.nodeSize, makeClusterName = opts.makeClusterName, makeClusterId = opts.makeClusterId;
|
|
90
|
+
var trees = new Array(maxZoom + 1);
|
|
91
|
+
// generate a cluster object for each point and index input points into a KD-tree
|
|
92
|
+
var clusters = new Array();
|
|
93
|
+
for (var i = 0; i < locations.length; i++) {
|
|
94
|
+
var x = getLocationLon(locations[i]);
|
|
95
|
+
var y = getLocationLat(locations[i]);
|
|
96
|
+
clusters.push({
|
|
97
|
+
x: lngX(x),
|
|
98
|
+
y: latY(y),
|
|
99
|
+
weight: getLocationWeight(getLocationId(locations[i])),
|
|
100
|
+
zoom: Infinity,
|
|
101
|
+
index: i,
|
|
102
|
+
parentId: -1, // parent cluster id
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
trees[maxZoom + 1] = new kdbush_1.default(clusters, getX, getY, nodeSize, Float32Array);
|
|
106
|
+
// cluster points on max zoom, then cluster the results on previous zoom, etc.;
|
|
107
|
+
// results in a cluster hierarchy across zoom levels
|
|
108
|
+
for (var z = maxZoom; z >= minZoom; z--) {
|
|
109
|
+
// create a new set of clusters for the zoom and index them with a KD-tree
|
|
110
|
+
clusters = cluster(clusters, z, trees[z + 1], opts);
|
|
111
|
+
trees[z] = new kdbush_1.default(clusters, getX, getY, nodeSize, Float32Array);
|
|
112
|
+
}
|
|
113
|
+
if (trees.length === 0) {
|
|
114
|
+
return [];
|
|
115
|
+
}
|
|
116
|
+
var numbersOfClusters = trees.map(function (d) { return d.points.length; });
|
|
117
|
+
var maxAvailZoom = numbersOfClusters.indexOf(numbersOfClusters[numbersOfClusters.length - 1]);
|
|
118
|
+
var minAvailZoom = Math.min(maxAvailZoom, numbersOfClusters.lastIndexOf(numbersOfClusters[0]));
|
|
119
|
+
var clusterLevels = new Array();
|
|
120
|
+
for (var zoom = minAvailZoom; zoom <= maxAvailZoom; zoom++) {
|
|
121
|
+
var childrenByParent = void 0;
|
|
122
|
+
var tree = trees[zoom];
|
|
123
|
+
if (zoom < maxAvailZoom) {
|
|
124
|
+
childrenByParent = (0, d3_array_1.rollup)(trees[zoom + 1].points, function (points) {
|
|
125
|
+
return points.map(function (p) {
|
|
126
|
+
return p.id ? makeClusterId(p.id) : getLocationId(locations[p.index]);
|
|
127
|
+
});
|
|
128
|
+
}, function (point) { return point.parentId; });
|
|
129
|
+
}
|
|
130
|
+
var nodes = [];
|
|
131
|
+
try {
|
|
132
|
+
for (var _b = (e_1 = void 0, __values(tree.points)), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
133
|
+
var point = _c.value;
|
|
134
|
+
var x = point.x, y = point.y, numPoints = point.numPoints;
|
|
135
|
+
if (isLeafPoint(point)) {
|
|
136
|
+
var location_1 = locations[point.index];
|
|
137
|
+
nodes.push({
|
|
138
|
+
id: getLocationId(location_1),
|
|
139
|
+
zoom: zoom,
|
|
140
|
+
lat: getLocationLat(location_1),
|
|
141
|
+
lon: getLocationLon(location_1),
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
else if (isClusterPoint(point)) {
|
|
145
|
+
var id = point.id;
|
|
146
|
+
var children = childrenByParent && childrenByParent.get(id);
|
|
147
|
+
if (!children) {
|
|
148
|
+
throw new Error("Cluster ".concat(id, " doesn't have children"));
|
|
149
|
+
}
|
|
150
|
+
nodes.push({
|
|
151
|
+
id: makeClusterId(id),
|
|
152
|
+
name: makeClusterName(id, numPoints),
|
|
153
|
+
zoom: zoom,
|
|
154
|
+
lat: yLat(y),
|
|
155
|
+
lon: xLng(x),
|
|
156
|
+
children: children,
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
162
|
+
finally {
|
|
163
|
+
try {
|
|
164
|
+
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
165
|
+
}
|
|
166
|
+
finally { if (e_1) throw e_1.error; }
|
|
167
|
+
}
|
|
168
|
+
clusterLevels.push({
|
|
169
|
+
zoom: zoom,
|
|
170
|
+
nodes: nodes,
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
return clusterLevels;
|
|
174
|
+
}
|
|
175
|
+
exports.clusterLocations = clusterLocations;
|
|
176
|
+
function createCluster(x, y, id, numPoints, weight) {
|
|
177
|
+
return {
|
|
178
|
+
x: x,
|
|
179
|
+
y: y,
|
|
180
|
+
zoom: Infinity,
|
|
181
|
+
id: id,
|
|
182
|
+
parentId: -1,
|
|
183
|
+
numPoints: numPoints,
|
|
184
|
+
weight: weight,
|
|
185
|
+
};
|
|
186
|
+
}
|
|
187
|
+
function cluster(points, zoom, tree, options) {
|
|
188
|
+
var e_2, _a;
|
|
189
|
+
var clusters = [];
|
|
190
|
+
var radius = options.radius, extent = options.extent;
|
|
191
|
+
var r = radius / (extent * Math.pow(2, zoom));
|
|
192
|
+
// loop through each point
|
|
193
|
+
for (var i = 0; i < points.length; i++) {
|
|
194
|
+
var p = points[i];
|
|
195
|
+
// if we've already visited the point at this zoom level, skip it
|
|
196
|
+
if (p.zoom <= zoom) {
|
|
197
|
+
continue;
|
|
198
|
+
}
|
|
199
|
+
p.zoom = zoom;
|
|
200
|
+
// find all nearby points
|
|
201
|
+
var neighborIds = tree.within(p.x, p.y, r);
|
|
202
|
+
var weight = p.weight || 1;
|
|
203
|
+
var numPoints = isClusterPoint(p) ? p.numPoints : 1;
|
|
204
|
+
var wx = p.x * weight;
|
|
205
|
+
var wy = p.y * weight;
|
|
206
|
+
// encode both zoom and point index on which the cluster originated
|
|
207
|
+
var id = (i << 5) + (zoom + 1);
|
|
208
|
+
try {
|
|
209
|
+
for (var neighborIds_1 = (e_2 = void 0, __values(neighborIds)), neighborIds_1_1 = neighborIds_1.next(); !neighborIds_1_1.done; neighborIds_1_1 = neighborIds_1.next()) {
|
|
210
|
+
var neighborId = neighborIds_1_1.value;
|
|
211
|
+
var b = tree.points[neighborId];
|
|
212
|
+
// filter out neighbors that are already processed
|
|
213
|
+
if (b.zoom <= zoom) {
|
|
214
|
+
continue;
|
|
215
|
+
}
|
|
216
|
+
b.zoom = zoom; // save the zoom (so it doesn't get processed twice)
|
|
217
|
+
var weight2 = b.weight || 1;
|
|
218
|
+
var numPoints2 = b.numPoints || 1;
|
|
219
|
+
wx += b.x * weight2; // accumulate coordinates for calculating weighted center
|
|
220
|
+
wy += b.y * weight2;
|
|
221
|
+
weight += weight2;
|
|
222
|
+
numPoints += numPoints2;
|
|
223
|
+
b.parentId = id;
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
|
227
|
+
finally {
|
|
228
|
+
try {
|
|
229
|
+
if (neighborIds_1_1 && !neighborIds_1_1.done && (_a = neighborIds_1.return)) _a.call(neighborIds_1);
|
|
230
|
+
}
|
|
231
|
+
finally { if (e_2) throw e_2.error; }
|
|
232
|
+
}
|
|
233
|
+
if (numPoints === 1) {
|
|
234
|
+
clusters.push(p);
|
|
235
|
+
}
|
|
236
|
+
else {
|
|
237
|
+
p.parentId = id;
|
|
238
|
+
clusters.push(createCluster(wx / weight, wy / weight, id, numPoints, weight));
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
return clusters;
|
|
242
|
+
}
|
|
243
|
+
// spherical mercator to longitude/latitude
|
|
244
|
+
function xLng(x) {
|
|
245
|
+
return (x - 0.5) * 360;
|
|
246
|
+
}
|
|
247
|
+
function yLat(y) {
|
|
248
|
+
var y2 = ((180 - y * 360) * Math.PI) / 180;
|
|
249
|
+
return (360 * Math.atan(Math.exp(y2))) / Math.PI - 90;
|
|
250
|
+
}
|
|
251
|
+
// longitude/latitude to spherical mercator in [0..1] range
|
|
252
|
+
function lngX(lng) {
|
|
253
|
+
return lng / 360 + 0.5;
|
|
254
|
+
}
|
|
255
|
+
function latY(lat) {
|
|
256
|
+
var sin = Math.sin((lat * Math.PI) / 180);
|
|
257
|
+
var y = 0.5 - (0.25 * Math.log((1 + sin) / (1 - sin))) / Math.PI;
|
|
258
|
+
return y < 0 ? 0 : y > 1 ? 1 : y;
|
|
259
|
+
}
|
|
260
|
+
function getX(p) {
|
|
261
|
+
return p.x;
|
|
262
|
+
}
|
|
263
|
+
function getY(p) {
|
|
264
|
+
return p.y;
|
|
265
|
+
}
|
|
266
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cluster.js","sourceRoot":"","sources":["../../src/cluster/cluster.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2022 FlowmapBlue\n * Copyright 2018-2020 Teralytics, modified by FlowmapBlue\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n *\n */\n\n/**\n * The code in this file is a based on https://github.com/mapbox/supercluster\n */\n\n// ISC License\n//\n// Copyright (c) 2016, Mapbox\n//\n// Permission to use, copy, modify, and/or distribute this software for any purpose\n// with or without fee is hereby granted, provided that the above copyright notice\n// and this permission notice appear in all copies.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\n// REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND\n// FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\n// INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS\n// OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER\n// TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF\n// THIS SOFTWARE.\n\nimport {rollup} from 'd3-array';\nimport KDBush from 'kdbush';\nimport {LocationWeightGetter} from './ClusterIndex';\nimport {Cluster, ClusterLevel, ClusterNode, LocationAccessors} from '../types';\n\nexport interface Options {\n  minZoom: number; // min zoom to generate clusters on\n  maxZoom: number; // max zoom level to cluster the points on\n  radius: number; // cluster radius in pixels\n  extent: number; // tile extent (radius is calculated relative to it)\n  nodeSize: number; // size of the KD-tree leaf node, affects performance\n  makeClusterName: (id: number, numPoints: number) => string | undefined;\n  makeClusterId: (id: number) => string;\n}\n\nconst defaultOptions: Options = {\n  minZoom: 0,\n  maxZoom: 16,\n  radius: 40,\n  extent: 512,\n  nodeSize: 64,\n  makeClusterName: (id: number, numPoints: number) => undefined,\n  makeClusterId: (id: number) => `{[${id}]}`,\n};\n\ninterface BasePoint {\n  x: number; // projected point coordinates\n  y: number;\n  weight: number;\n  zoom: number; // the last zoom the point was processed at\n  parentId: number; // parent cluster id\n}\n\ninterface LeafPoint extends BasePoint {\n  index: number; // index of the source feature in the original input array,\n}\n\ninterface ClusterPoint extends BasePoint {\n  id: number;\n  numPoints: number;\n}\n\ntype Point = LeafPoint | ClusterPoint;\n\nexport function isLeafPoint(p: Point): p is LeafPoint {\n  const {index} = p as LeafPoint;\n  return index != null;\n}\n\nexport function isClusterPoint(p: Point): p is ClusterPoint {\n  const {id} = p as ClusterPoint;\n  return id != null;\n}\n\ntype ZoomLevelKDBush = any;\n\nexport function clusterLocations<L>(\n  locations: L[],\n  locationAccessors: LocationAccessors<L>,\n  getLocationWeight: LocationWeightGetter,\n  options?: Partial<Options>,\n): ClusterLevel[] {\n  const {getLocationLon, getLocationLat, getLocationId} = locationAccessors;\n  const opts = {\n    ...defaultOptions,\n    ...options,\n  };\n  const {minZoom, maxZoom, nodeSize, makeClusterName, makeClusterId} = opts;\n\n  const trees = new Array<ZoomLevelKDBush>(maxZoom + 1);\n\n  // generate a cluster object for each point and index input points into a KD-tree\n  let clusters = new Array<Point>();\n  for (let i = 0; i < locations.length; i++) {\n    const x = getLocationLon(locations[i]);\n    const y = getLocationLat(locations[i]);\n    clusters.push({\n      x: lngX(x), // projected point coordinates\n      y: latY(y),\n      weight: getLocationWeight(getLocationId(locations[i])),\n      zoom: Infinity, // the last zoom the point was processed at\n      index: i, // index of the source feature in the original input array,\n      parentId: -1, // parent cluster id\n    });\n  }\n  trees[maxZoom + 1] = new KDBush(clusters, getX, getY, nodeSize, Float32Array);\n\n  // cluster points on max zoom, then cluster the results on previous zoom, etc.;\n  // results in a cluster hierarchy across zoom levels\n  for (let z = maxZoom; z >= minZoom; z--) {\n    // create a new set of clusters for the zoom and index them with a KD-tree\n    clusters = cluster(clusters, z, trees[z + 1], opts);\n    trees[z] = new KDBush(clusters, getX, getY, nodeSize, Float32Array);\n  }\n\n  if (trees.length === 0) {\n    return [];\n  }\n  const numbersOfClusters = trees.map((d) => d.points.length);\n  const maxAvailZoom = numbersOfClusters.indexOf(\n    numbersOfClusters[numbersOfClusters.length - 1],\n  );\n  const minAvailZoom = Math.min(\n    maxAvailZoom,\n    numbersOfClusters.lastIndexOf(numbersOfClusters[0]),\n  );\n\n  const clusterLevels = new Array<ClusterLevel>();\n  for (let zoom = minAvailZoom; zoom <= maxAvailZoom; zoom++) {\n    let childrenByParent: Map<number, string[]> | undefined;\n    const tree = trees[zoom];\n    if (zoom < maxAvailZoom) {\n      childrenByParent = rollup<Point, string[], number>(\n        trees[zoom + 1].points,\n        (points: any[]) =>\n          points.map((p: any) =>\n            p.id ? makeClusterId(p.id) : getLocationId(locations[p.index]),\n          ),\n        (point: any) => point.parentId,\n      );\n    }\n\n    const nodes: ClusterNode[] = [];\n    for (const point of tree.points) {\n      const {x, y, numPoints} = point;\n      if (isLeafPoint(point)) {\n        const location = locations[point.index];\n        nodes.push({\n          id: getLocationId(location),\n          zoom,\n          lat: getLocationLat(location),\n          lon: getLocationLon(location),\n        });\n      } else if (isClusterPoint(point)) {\n        const {id} = point;\n        const children = childrenByParent && childrenByParent.get(id);\n        if (!children) {\n          throw new Error(`Cluster ${id} doesn't have children`);\n        }\n        nodes.push({\n          id: makeClusterId(id),\n          name: makeClusterName(id, numPoints),\n          zoom,\n          lat: yLat(y),\n          lon: xLng(x),\n          children,\n        } as Cluster);\n      }\n    }\n    clusterLevels.push({\n      zoom,\n      nodes,\n    });\n  }\n  return clusterLevels;\n}\n\nfunction createCluster(\n  x: number,\n  y: number,\n  id: number,\n  numPoints: number,\n  weight: number,\n): ClusterPoint {\n  return {\n    x, // weighted cluster center\n    y,\n    zoom: Infinity, // the last zoom the cluster was processed at\n    id, // encodes index of the first child of the cluster and its zoom level\n    parentId: -1, // parent cluster id\n    numPoints,\n    weight,\n  };\n}\n\nfunction cluster(\n  points: Point[],\n  zoom: number,\n  tree: ZoomLevelKDBush,\n  options: Options,\n) {\n  const clusters: Point[] = [];\n  const {radius, extent} = options;\n  const r = radius / (extent * Math.pow(2, zoom));\n\n  // loop through each point\n  for (let i = 0; i < points.length; i++) {\n    const p = points[i];\n    // if we've already visited the point at this zoom level, skip it\n    if (p.zoom <= zoom) {\n      continue;\n    }\n    p.zoom = zoom;\n\n    // find all nearby points\n    const neighborIds = tree.within(p.x, p.y, r);\n\n    let weight = p.weight || 1;\n    let numPoints = isClusterPoint(p) ? p.numPoints : 1;\n    let wx = p.x * weight;\n    let wy = p.y * weight;\n\n    // encode both zoom and point index on which the cluster originated\n    const id = (i << 5) + (zoom + 1);\n\n    for (const neighborId of neighborIds) {\n      const b = tree.points[neighborId];\n      // filter out neighbors that are already processed\n      if (b.zoom <= zoom) {\n        continue;\n      }\n      b.zoom = zoom; // save the zoom (so it doesn't get processed twice)\n\n      const weight2 = b.weight || 1;\n      const numPoints2 = b.numPoints || 1;\n      wx += b.x * weight2; // accumulate coordinates for calculating weighted center\n      wy += b.y * weight2;\n\n      weight += weight2;\n      numPoints += numPoints2;\n      b.parentId = id;\n    }\n\n    if (numPoints === 1) {\n      clusters.push(p);\n    } else {\n      p.parentId = id;\n      clusters.push(\n        createCluster(wx / weight, wy / weight, id, numPoints, weight),\n      );\n    }\n  }\n\n  return clusters;\n}\n\n// spherical mercator to longitude/latitude\nfunction xLng(x: number) {\n  return (x - 0.5) * 360;\n}\n\nfunction yLat(y: number) {\n  const y2 = ((180 - y * 360) * Math.PI) / 180;\n  return (360 * Math.atan(Math.exp(y2))) / Math.PI - 90;\n}\n\n// longitude/latitude to spherical mercator in [0..1] range\nfunction lngX(lng: number) {\n  return lng / 360 + 0.5;\n}\n\nfunction latY(lat: number) {\n  const sin = Math.sin((lat * Math.PI) / 180);\n  const y = 0.5 - (0.25 * Math.log((1 + sin) / (1 - sin))) / Math.PI;\n  return y < 0 ? 0 : y > 1 ? 1 : y;\n}\n\nfunction getX(p: Point) {\n  return p.x;\n}\n\nfunction getY(p: Point) {\n  return p.y;\n}\n"]}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { SettingsState } from './FlowmapState';
|
|
2
|
+
export declare type ColorScale = (value: number) => RGBA;
|
|
3
|
+
export declare type RGBA = [number, number, number, number];
|
|
4
|
+
export declare function opacityFloatToInteger(opacity: number): number;
|
|
5
|
+
export declare function opacifyHex(hexCode: string, opacity: number): string;
|
|
6
|
+
export declare function colorAsRgba(color: string | number[]): RGBA;
|
|
7
|
+
export declare enum ColorScheme {
|
|
8
|
+
primary = "#162d3c"
|
|
9
|
+
}
|
|
10
|
+
export declare const GRAYISH: string[];
|
|
11
|
+
export declare const schemeTeal: string[];
|
|
12
|
+
export declare const DEFAULT_COLOR_SCHEME: string[];
|
|
13
|
+
export declare const COLOR_SCHEMES: {
|
|
14
|
+
[key: string]: string[];
|
|
15
|
+
};
|
|
16
|
+
export declare const COLOR_SCHEME_KEYS: string[];
|
|
17
|
+
export declare function getFlowmapColors(settingsState: SettingsState): Colors | DiffColors;
|
|
18
|
+
export declare function getColors(diffMode: boolean, colorScheme: string | string[] | undefined, darkMode: boolean, fadeEnabled: boolean, fadeOpacityEnabled: boolean, fadeAmount: number, animate: boolean): Colors | DiffColors;
|
|
19
|
+
export declare function createFlowColorScale(domain: [number, number], scheme: string[], animate: boolean | undefined): ColorScale;
|
|
20
|
+
export declare function getFlowColorScale(colors: ColorsRGBA | DiffColorsRGBA, magnitudeExtent: [number, number] | undefined, animate: boolean | undefined): (magnitude: number) => [number, number, number, number];
|
|
21
|
+
export declare function isDiffColors(colors: DiffColors | Colors): colors is DiffColors;
|
|
22
|
+
export declare function isDiffColorsRGBA(colors: DiffColorsRGBA | ColorsRGBA): colors is DiffColorsRGBA;
|
|
23
|
+
export interface FlowColors {
|
|
24
|
+
scheme?: string[];
|
|
25
|
+
highlighted?: string;
|
|
26
|
+
}
|
|
27
|
+
export interface LocationCircleColors {
|
|
28
|
+
inner?: string;
|
|
29
|
+
outgoing?: string;
|
|
30
|
+
incoming?: string;
|
|
31
|
+
highlighted?: string;
|
|
32
|
+
empty?: string;
|
|
33
|
+
outlineEmptyMix?: number;
|
|
34
|
+
}
|
|
35
|
+
export interface LocationAreaColors {
|
|
36
|
+
outline?: string;
|
|
37
|
+
normal?: string;
|
|
38
|
+
selected?: string;
|
|
39
|
+
highlighted?: string;
|
|
40
|
+
connected?: string;
|
|
41
|
+
}
|
|
42
|
+
export interface BaseColors {
|
|
43
|
+
darkMode?: boolean;
|
|
44
|
+
locationAreas?: LocationAreaColors;
|
|
45
|
+
dimmedOpacity?: number;
|
|
46
|
+
outlineColor?: string;
|
|
47
|
+
}
|
|
48
|
+
export interface Colors extends BaseColors {
|
|
49
|
+
flows?: FlowColors;
|
|
50
|
+
locationCircles?: LocationCircleColors;
|
|
51
|
+
}
|
|
52
|
+
export interface FlowAndCircleColors {
|
|
53
|
+
flows?: FlowColors;
|
|
54
|
+
locationCircles?: LocationCircleColors;
|
|
55
|
+
}
|
|
56
|
+
export interface DiffColors extends BaseColors {
|
|
57
|
+
positive?: FlowAndCircleColors;
|
|
58
|
+
negative?: FlowAndCircleColors;
|
|
59
|
+
}
|
|
60
|
+
export interface FlowColorsRGBA {
|
|
61
|
+
scheme: string[];
|
|
62
|
+
highlighted: RGBA;
|
|
63
|
+
}
|
|
64
|
+
export interface LocationCircleColorsRGBA {
|
|
65
|
+
inner: RGBA;
|
|
66
|
+
outgoing: RGBA;
|
|
67
|
+
incoming: RGBA;
|
|
68
|
+
highlighted: RGBA;
|
|
69
|
+
empty: RGBA;
|
|
70
|
+
outlineEmptyMix: number;
|
|
71
|
+
}
|
|
72
|
+
export interface LocationAreaColorsRGBA {
|
|
73
|
+
outline: RGBA;
|
|
74
|
+
normal: RGBA;
|
|
75
|
+
selected: RGBA;
|
|
76
|
+
highlighted: RGBA;
|
|
77
|
+
connected: RGBA;
|
|
78
|
+
}
|
|
79
|
+
export interface BaseColorsRGBA {
|
|
80
|
+
darkMode: boolean;
|
|
81
|
+
locationAreas: LocationAreaColorsRGBA;
|
|
82
|
+
dimmedOpacity: number;
|
|
83
|
+
outlineColor: RGBA;
|
|
84
|
+
}
|
|
85
|
+
export interface ColorsRGBA extends BaseColorsRGBA {
|
|
86
|
+
flows: FlowColorsRGBA;
|
|
87
|
+
locationCircles: LocationCircleColorsRGBA;
|
|
88
|
+
}
|
|
89
|
+
export interface FlowAndCircleColorsRGBA {
|
|
90
|
+
flows: FlowColorsRGBA;
|
|
91
|
+
locationCircles: LocationCircleColorsRGBA;
|
|
92
|
+
}
|
|
93
|
+
export interface DiffColorsRGBA extends BaseColorsRGBA {
|
|
94
|
+
positive: FlowAndCircleColorsRGBA;
|
|
95
|
+
negative: FlowAndCircleColorsRGBA;
|
|
96
|
+
}
|
|
97
|
+
export declare function getColorsRGBA(colors: Colors | undefined): ColorsRGBA;
|
|
98
|
+
export declare function getDiffColorsRGBA(colors: DiffColors | undefined): DiffColorsRGBA;
|
|
99
|
+
export declare function rgbaAsString(color: RGBA): string;
|
|
100
|
+
export declare function midpoint(a: number, b: number, zeroToOne: number): number;
|
|
101
|
+
export declare function mixColorsRGBA(color1: RGBA, color2: RGBA, zeroToOne: number): RGBA;
|
|
102
|
+
export default getColors;
|
|
103
|
+
//# sourceMappingURL=colors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"colors.d.ts","sourceRoot":"","sources":["../src/colors.ts"],"names":[],"mappings":"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"}
|