@flowmap.gl/layers 8.0.0-alpha.25 → 8.0.0-alpha.27
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/.turbo/turbo-build.log +9 -0
- package/.turbo/turbo-dev.log +0 -0
- package/LICENSE +2 -2
- package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayer.d.ts.map +1 -1
- package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayer.js +13 -20
- package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerFragment.glsl.d.ts.map +1 -1
- package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerFragment.glsl.js +4 -16
- package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerVertex.glsl.d.ts.map +1 -1
- package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerVertex.glsl.js +4 -16
- package/dist/AnimatedFlowLinesLayer/index.d.ts.map +1 -1
- package/dist/AnimatedFlowLinesLayer/index.js +6 -1
- package/dist/FlowCirclesLayer/FlowCirclesLayer.d.ts +1 -1
- package/dist/FlowCirclesLayer/FlowCirclesLayer.d.ts.map +1 -1
- package/dist/FlowCirclesLayer/FlowCirclesLayer.js +9 -18
- package/dist/FlowCirclesLayer/FlowCirclesLayerFragment.glsl.d.ts.map +1 -1
- package/dist/FlowCirclesLayer/FlowCirclesLayerFragment.glsl.js +4 -16
- package/dist/FlowCirclesLayer/FlowCirclesLayerVertex.glsl.d.ts.map +1 -1
- package/dist/FlowCirclesLayer/FlowCirclesLayerVertex.glsl.js +4 -16
- package/dist/FlowCirclesLayer/index.d.ts.map +1 -1
- package/dist/FlowCirclesLayer/index.js +6 -1
- package/dist/FlowLinesLayer/FlowLinesLayer.d.ts.map +1 -1
- package/dist/FlowLinesLayer/FlowLinesLayer.js +18 -20
- package/dist/FlowLinesLayer/FlowLinesLayerFragment.glsl.d.ts.map +1 -1
- package/dist/FlowLinesLayer/FlowLinesLayerFragment.glsl.js +4 -16
- package/dist/FlowLinesLayer/FlowLinesLayerVertex.glsl.d.ts.map +1 -1
- package/dist/FlowLinesLayer/FlowLinesLayerVertex.glsl.js +4 -16
- package/dist/FlowLinesLayer/index.d.ts.map +1 -1
- package/dist/FlowLinesLayer/index.js +6 -1
- package/dist/FlowmapLayer.d.ts +9 -7
- package/dist/FlowmapLayer.d.ts.map +1 -1
- package/dist/FlowmapLayer.js +144 -116
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +6 -1
- package/dist/types.d.ts +5 -5
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +6 -1
- package/package.json +4 -3
- package/src/AnimatedFlowLinesLayer/AnimatedFlowLinesLayer.ts +3 -15
- package/src/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerFragment.glsl.ts +3 -15
- package/src/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerVertex.glsl.ts +3 -15
- package/src/AnimatedFlowLinesLayer/index.ts +6 -0
- package/src/FlowCirclesLayer/FlowCirclesLayer.ts +3 -15
- package/src/FlowCirclesLayer/FlowCirclesLayerFragment.glsl.ts +3 -15
- package/src/FlowCirclesLayer/FlowCirclesLayerVertex.glsl.ts +3 -15
- package/src/FlowCirclesLayer/index.ts +6 -0
- package/src/FlowLinesLayer/FlowLinesLayer.ts +3 -15
- package/src/FlowLinesLayer/FlowLinesLayerFragment.glsl.ts +3 -15
- package/src/FlowLinesLayer/FlowLinesLayerVertex.glsl.ts +3 -15
- package/src/FlowLinesLayer/index.ts +6 -0
- package/src/FlowmapLayer.ts +17 -17
- package/src/index.ts +6 -0
- package/src/types.ts +6 -0
package/dist/FlowmapLayer.js
CHANGED
|
@@ -1,27 +1,7 @@
|
|
|
1
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
-
});
|
|
9
|
-
};
|
|
10
1
|
/*
|
|
11
|
-
* Copyright
|
|
12
|
-
*
|
|
13
|
-
*
|
|
14
|
-
* you may not use this file except in compliance with the License.
|
|
15
|
-
* You may obtain a copy of the License at
|
|
16
|
-
*
|
|
17
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
18
|
-
*
|
|
19
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
20
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
21
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
22
|
-
* See the License for the specific language governing permissions and
|
|
23
|
-
* limitations under the License.
|
|
24
|
-
*
|
|
2
|
+
* Copyright (c) Flowmap.gl contributors
|
|
3
|
+
* Copyright (c) 2018-2020 Teralytics
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
25
5
|
*/
|
|
26
6
|
import { CompositeLayer } from '@deck.gl/core';
|
|
27
7
|
import { ScatterplotLayer, TextLayer } from '@deck.gl/layers';
|
|
@@ -32,6 +12,7 @@ import FlowLinesLayer from './FlowLinesLayer';
|
|
|
32
12
|
import { PickingType, } from './types';
|
|
33
13
|
const PROPS_TO_CAUSE_LAYER_DATA_UPDATE = [
|
|
34
14
|
'filter',
|
|
15
|
+
'locationsEnabled',
|
|
35
16
|
'locationTotalsEnabled',
|
|
36
17
|
'locationLabelsEnabled',
|
|
37
18
|
'adaptiveScalesEnabled',
|
|
@@ -52,9 +33,11 @@ var HighlightType;
|
|
|
52
33
|
HighlightType["LOCATION"] = "location";
|
|
53
34
|
HighlightType["FLOW"] = "flow";
|
|
54
35
|
})(HighlightType || (HighlightType = {}));
|
|
55
|
-
|
|
36
|
+
class FlowmapLayer extends CompositeLayer {
|
|
56
37
|
constructor(props) {
|
|
57
|
-
super(
|
|
38
|
+
super({
|
|
39
|
+
...props,
|
|
40
|
+
onHover: (info, event) => {
|
|
58
41
|
const startTime = Date.now();
|
|
59
42
|
this.setState({
|
|
60
43
|
highlightedObject: this._getHighlightedObject(info),
|
|
@@ -63,8 +46,7 @@ export default class FlowmapLayer extends CompositeLayer {
|
|
|
63
46
|
const { onHover } = props;
|
|
64
47
|
if (onHover) {
|
|
65
48
|
this._getFlowmapLayerPickingInfo(info).then((info) => {
|
|
66
|
-
|
|
67
|
-
if (((_b = (_a = this.state) === null || _a === void 0 ? void 0 : _a.lastHoverTime) !== null && _b !== void 0 ? _b : 0) <= startTime) {
|
|
49
|
+
if ((this.state?.lastHoverTime ?? 0) <= startTime) {
|
|
68
50
|
this.setState({ pickingInfo: info });
|
|
69
51
|
onHover(info, event);
|
|
70
52
|
}
|
|
@@ -73,7 +55,8 @@ export default class FlowmapLayer extends CompositeLayer {
|
|
|
73
55
|
}
|
|
74
56
|
});
|
|
75
57
|
}
|
|
76
|
-
},
|
|
58
|
+
},
|
|
59
|
+
onClick: (info, event) => {
|
|
77
60
|
const { onClick } = props;
|
|
78
61
|
const startTime = Date.now();
|
|
79
62
|
this.setState({
|
|
@@ -81,8 +64,7 @@ export default class FlowmapLayer extends CompositeLayer {
|
|
|
81
64
|
});
|
|
82
65
|
if (onClick) {
|
|
83
66
|
this._getFlowmapLayerPickingInfo(info).then((info) => {
|
|
84
|
-
|
|
85
|
-
if (((_b = (_a = this.state) === null || _a === void 0 ? void 0 : _a.lastClickTime) !== null && _b !== void 0 ? _b : 0) <= startTime) {
|
|
67
|
+
if ((this.state?.lastClickTime ?? 0) <= startTime) {
|
|
86
68
|
this.setState({ pickingInfo: info });
|
|
87
69
|
if (info) {
|
|
88
70
|
onClick(info, event);
|
|
@@ -93,7 +75,8 @@ export default class FlowmapLayer extends CompositeLayer {
|
|
|
93
75
|
}
|
|
94
76
|
});
|
|
95
77
|
}
|
|
96
|
-
}
|
|
78
|
+
},
|
|
79
|
+
});
|
|
97
80
|
}
|
|
98
81
|
initializeState() {
|
|
99
82
|
this.state = {
|
|
@@ -107,12 +90,15 @@ export default class FlowmapLayer extends CompositeLayer {
|
|
|
107
90
|
};
|
|
108
91
|
}
|
|
109
92
|
getPickingInfo({ info }) {
|
|
110
|
-
var _a, _b;
|
|
111
93
|
// This is for onHover event handlers set on the <DeckGL> component
|
|
112
94
|
if (!info.object) {
|
|
113
|
-
const object =
|
|
95
|
+
const object = this.state?.pickingInfo?.object;
|
|
114
96
|
if (object) {
|
|
115
|
-
return
|
|
97
|
+
return {
|
|
98
|
+
...info,
|
|
99
|
+
object,
|
|
100
|
+
picked: true,
|
|
101
|
+
};
|
|
116
102
|
}
|
|
117
103
|
}
|
|
118
104
|
return info;
|
|
@@ -172,8 +158,9 @@ export default class FlowmapLayer extends CompositeLayer {
|
|
|
172
158
|
}
|
|
173
159
|
}
|
|
174
160
|
_getSettingsState() {
|
|
175
|
-
const { locationTotalsEnabled, locationLabelsEnabled, adaptiveScalesEnabled, animationEnabled, clusteringEnabled, clusteringLevel, fadeEnabled, fadeOpacityEnabled, clusteringAuto, darkMode, fadeAmount, colorScheme, highlightColor, maxTopFlowsDisplayNum, } = this.props;
|
|
161
|
+
const { locationsEnabled, locationTotalsEnabled, locationLabelsEnabled, adaptiveScalesEnabled, animationEnabled, clusteringEnabled, clusteringLevel, fadeEnabled, fadeOpacityEnabled, clusteringAuto, darkMode, fadeAmount, colorScheme, highlightColor, maxTopFlowsDisplayNum, } = this.props;
|
|
176
162
|
return {
|
|
163
|
+
locationsEnabled,
|
|
177
164
|
locationTotalsEnabled,
|
|
178
165
|
locationLabelsEnabled,
|
|
179
166
|
adaptiveScalesEnabled,
|
|
@@ -197,70 +184,90 @@ export default class FlowmapLayer extends CompositeLayer {
|
|
|
197
184
|
settings: this._getSettingsState(),
|
|
198
185
|
};
|
|
199
186
|
}
|
|
200
|
-
_getFlowmapLayerPickingInfo(info) {
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
187
|
+
async _getFlowmapLayerPickingInfo(info) {
|
|
188
|
+
const { index, sourceLayer } = info;
|
|
189
|
+
const { dataProvider, accessors } = this.state || {};
|
|
190
|
+
if (!dataProvider || !accessors) {
|
|
191
|
+
return undefined;
|
|
192
|
+
}
|
|
193
|
+
const commonInfo = {
|
|
194
|
+
...info,
|
|
195
|
+
picked: info.picked,
|
|
196
|
+
layer: info.layer,
|
|
197
|
+
index: info.index,
|
|
198
|
+
x: info.x,
|
|
199
|
+
y: info.y,
|
|
200
|
+
coordinate: info.coordinate,
|
|
201
|
+
event: info.event,
|
|
202
|
+
};
|
|
203
|
+
if (sourceLayer instanceof FlowLinesLayer ||
|
|
204
|
+
sourceLayer instanceof AnimatedFlowLinesLayer) {
|
|
205
|
+
const flow = index === -1 ? undefined : await dataProvider.getFlowByIndex(index);
|
|
206
|
+
if (flow) {
|
|
207
|
+
const origin = await dataProvider.getLocationById(accessors.getFlowOriginId(flow));
|
|
208
|
+
const dest = await dataProvider.getLocationById(accessors.getFlowDestId(flow));
|
|
209
|
+
if (origin && dest) {
|
|
210
|
+
return {
|
|
211
|
+
...commonInfo,
|
|
212
|
+
object: {
|
|
213
|
+
type: PickingType.FLOW,
|
|
214
|
+
flow,
|
|
215
|
+
origin: origin,
|
|
216
|
+
dest: dest,
|
|
217
|
+
count: accessors.getFlowMagnitude(flow),
|
|
218
|
+
},
|
|
219
|
+
};
|
|
224
220
|
}
|
|
225
221
|
}
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
222
|
+
}
|
|
223
|
+
else if (sourceLayer instanceof FlowCirclesLayer) {
|
|
224
|
+
const location = index === -1 ? undefined : await dataProvider.getLocationByIndex(index);
|
|
225
|
+
if (location) {
|
|
226
|
+
const id = accessors.getLocationId(location);
|
|
227
|
+
const name = accessors.getLocationName(location);
|
|
228
|
+
const totals = await dataProvider.getTotalsForLocation(id);
|
|
229
|
+
const { circleAttributes } = this.state?.layersData || {};
|
|
230
|
+
if (totals && circleAttributes) {
|
|
231
|
+
const circleRadius = getOuterCircleRadiusByIndex(circleAttributes, info.index);
|
|
232
|
+
return {
|
|
233
|
+
...commonInfo,
|
|
234
|
+
object: {
|
|
235
|
+
type: PickingType.LOCATION,
|
|
236
|
+
location,
|
|
237
|
+
id,
|
|
238
|
+
name,
|
|
239
|
+
totals,
|
|
240
|
+
circleRadius: circleRadius,
|
|
241
|
+
},
|
|
242
|
+
};
|
|
244
243
|
}
|
|
245
244
|
}
|
|
246
|
-
|
|
247
|
-
|
|
245
|
+
}
|
|
246
|
+
return undefined;
|
|
248
247
|
}
|
|
249
248
|
_getHighlightedObject(info) {
|
|
250
|
-
var _a, _b;
|
|
251
249
|
const { index, sourceLayer } = info;
|
|
252
250
|
if (index < 0)
|
|
253
251
|
return undefined;
|
|
254
252
|
if (sourceLayer instanceof FlowLinesLayer ||
|
|
255
253
|
sourceLayer instanceof AnimatedFlowLinesLayer) {
|
|
256
|
-
const { lineAttributes } =
|
|
254
|
+
const { lineAttributes } = this.state?.layersData || {};
|
|
257
255
|
if (lineAttributes) {
|
|
258
256
|
let attrs = getFlowLineAttributesByIndex(lineAttributes, index);
|
|
259
257
|
if (this.props.fadeOpacityEnabled) {
|
|
260
|
-
attrs =
|
|
258
|
+
attrs = {
|
|
259
|
+
...attrs,
|
|
260
|
+
attributes: {
|
|
261
|
+
...attrs.attributes,
|
|
262
|
+
getColor: {
|
|
263
|
+
...attrs.attributes.getColor,
|
|
264
|
+
value: new Uint8Array([
|
|
261
265
|
...attrs.attributes.getColor.value.slice(0, 3),
|
|
262
266
|
255, // the highlight color should be always opaque
|
|
263
|
-
])
|
|
267
|
+
]),
|
|
268
|
+
},
|
|
269
|
+
},
|
|
270
|
+
};
|
|
264
271
|
}
|
|
265
272
|
return {
|
|
266
273
|
type: HighlightType.FLOW,
|
|
@@ -269,7 +276,7 @@ export default class FlowmapLayer extends CompositeLayer {
|
|
|
269
276
|
}
|
|
270
277
|
}
|
|
271
278
|
else if (sourceLayer instanceof FlowCirclesLayer) {
|
|
272
|
-
const { circleAttributes } =
|
|
279
|
+
const { circleAttributes } = this.state?.layersData || {};
|
|
273
280
|
if (circleAttributes) {
|
|
274
281
|
return {
|
|
275
282
|
type: HighlightType.LOCATION,
|
|
@@ -281,9 +288,8 @@ export default class FlowmapLayer extends CompositeLayer {
|
|
|
281
288
|
return undefined;
|
|
282
289
|
}
|
|
283
290
|
renderLayers() {
|
|
284
|
-
var _a;
|
|
285
291
|
const layers = [];
|
|
286
|
-
if (
|
|
292
|
+
if (this.state?.layersData) {
|
|
287
293
|
const { layersData, highlightedObject } = this.state;
|
|
288
294
|
const { circleAttributes, lineAttributes, locationLabels } = layersData || {};
|
|
289
295
|
if (circleAttributes && lineAttributes) {
|
|
@@ -291,17 +297,33 @@ export default class FlowmapLayer extends CompositeLayer {
|
|
|
291
297
|
const outlineColor = colorAsRgba(flowmapColors.outlineColor || (this.props.darkMode ? '#000' : '#fff'));
|
|
292
298
|
const commonLineLayerProps = {
|
|
293
299
|
data: lineAttributes,
|
|
294
|
-
parameters:
|
|
300
|
+
parameters: {
|
|
301
|
+
...this.props.parameters,
|
|
295
302
|
// prevent z-fighting at non-zero bearing/pitch
|
|
296
|
-
depthTest: false
|
|
303
|
+
depthTest: false,
|
|
304
|
+
},
|
|
297
305
|
};
|
|
298
306
|
if (this.props.animationEnabled) {
|
|
299
307
|
layers.push(
|
|
300
308
|
// @ts-ignore
|
|
301
|
-
new AnimatedFlowLinesLayer(
|
|
309
|
+
new AnimatedFlowLinesLayer({
|
|
310
|
+
...this.getSubLayerProps({
|
|
311
|
+
...commonLineLayerProps,
|
|
312
|
+
id: 'animated-flow-lines',
|
|
313
|
+
drawOutline: false,
|
|
314
|
+
thicknessUnit: 20,
|
|
315
|
+
}),
|
|
316
|
+
}));
|
|
302
317
|
}
|
|
303
318
|
else {
|
|
304
|
-
layers.push(new FlowLinesLayer(
|
|
319
|
+
layers.push(new FlowLinesLayer({
|
|
320
|
+
...this.getSubLayerProps({
|
|
321
|
+
...commonLineLayerProps,
|
|
322
|
+
id: 'flow-lines',
|
|
323
|
+
drawOutline: true,
|
|
324
|
+
outlineColor: outlineColor,
|
|
325
|
+
}),
|
|
326
|
+
}));
|
|
305
327
|
}
|
|
306
328
|
layers.push(new FlowCirclesLayer(this.getSubLayerProps({
|
|
307
329
|
id: 'circles',
|
|
@@ -314,33 +336,37 @@ export default class FlowmapLayer extends CompositeLayer {
|
|
|
314
336
|
if (highlightedObject) {
|
|
315
337
|
switch (highlightedObject.type) {
|
|
316
338
|
case HighlightType.LOCATION:
|
|
317
|
-
layers.push(new ScatterplotLayer(
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
339
|
+
layers.push(new ScatterplotLayer({
|
|
340
|
+
...this.getSubLayerProps({
|
|
341
|
+
id: 'location-highlight',
|
|
342
|
+
data: [highlightedObject],
|
|
343
|
+
pickable: false,
|
|
344
|
+
antialiasing: true,
|
|
345
|
+
stroked: true,
|
|
346
|
+
filled: false,
|
|
347
|
+
lineWidthUnits: 'pixels',
|
|
348
|
+
getLineWidth: 2,
|
|
349
|
+
radiusUnits: 'pixels',
|
|
350
|
+
getRadius: (d) => d.radius,
|
|
351
|
+
getLineColor: colorAsRgba(this.props.highlightColor),
|
|
352
|
+
getPosition: (d) => d.coords,
|
|
353
|
+
}),
|
|
354
|
+
}));
|
|
331
355
|
break;
|
|
332
356
|
case HighlightType.FLOW:
|
|
333
|
-
layers.push(new FlowLinesLayer(
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
357
|
+
layers.push(new FlowLinesLayer({
|
|
358
|
+
...this.getSubLayerProps({
|
|
359
|
+
id: 'flow-highlight',
|
|
360
|
+
data: highlightedObject.lineAttributes,
|
|
361
|
+
drawOutline: true,
|
|
362
|
+
pickable: false,
|
|
363
|
+
outlineColor: colorAsRgba(this.props.highlightColor),
|
|
364
|
+
outlineThickness: 1,
|
|
365
|
+
parameters: {
|
|
366
|
+
depthTest: false,
|
|
367
|
+
},
|
|
368
|
+
}),
|
|
369
|
+
}));
|
|
344
370
|
break;
|
|
345
371
|
}
|
|
346
372
|
}
|
|
@@ -375,6 +401,7 @@ export default class FlowmapLayer extends CompositeLayer {
|
|
|
375
401
|
FlowmapLayer.defaultProps = {
|
|
376
402
|
darkMode: true,
|
|
377
403
|
fadeAmount: 50,
|
|
404
|
+
locationsEnabled: true,
|
|
378
405
|
locationTotalsEnabled: true,
|
|
379
406
|
locationLabelsEnabled: false,
|
|
380
407
|
animationEnabled: false,
|
|
@@ -388,6 +415,7 @@ FlowmapLayer.defaultProps = {
|
|
|
388
415
|
highlightColor: 'orange',
|
|
389
416
|
maxTopFlowsDisplayNum: 5000,
|
|
390
417
|
};
|
|
418
|
+
export default FlowmapLayer;
|
|
391
419
|
function pickViewportProps(viewport) {
|
|
392
420
|
const { width, height, longitude, latitude, zoom, pitch, bearing } = viewport;
|
|
393
421
|
return {
|
|
@@ -400,4 +428,4 @@ function pickViewportProps(viewport) {
|
|
|
400
428
|
bearing,
|
|
401
429
|
};
|
|
402
430
|
}
|
|
403
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FlowmapLayer.js","sourceRoot":"","sources":["../src/FlowmapLayer.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2022 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 */\nimport {CompositeLayer} from '@deck.gl/core';\nimport {ScatterplotLayer, TextLayer} from '@deck.gl/layers';\nimport {\n  colorAsRgba,\n  FilterState,\n  FlowLinesLayerAttributes,\n  FlowmapAggregateAccessors,\n  FlowmapData,\n  FlowmapDataAccessors,\n  FlowmapDataProvider,\n  getFlowLineAttributesByIndex,\n  getFlowmapColors,\n  getLocationCoordsByIndex,\n  getOuterCircleRadiusByIndex,\n  isFlowmapData,\n  isFlowmapDataProvider,\n  LayersData,\n  LocalFlowmapDataProvider,\n  ViewportProps,\n} from '@flowmap.gl/data';\nimport AnimatedFlowLinesLayer from './AnimatedFlowLinesLayer';\nimport FlowCirclesLayer from './FlowCirclesLayer';\nimport FlowLinesLayer from './FlowLinesLayer';\nimport {\n  FlowmapLayerPickingInfo,\n  LayerProps,\n  PickingInfo,\n  PickingType,\n} from './types';\n\nexport type FlowmapLayerProps<L, F> = {\n  data?: FlowmapData<L, F>;\n  dataProvider?: FlowmapDataProvider<L, F>;\n  filter?: FilterState;\n  locationTotalsEnabled?: boolean;\n  locationLabelsEnabled?: boolean;\n  adaptiveScalesEnabled?: boolean;\n  animationEnabled?: boolean;\n  clusteringEnabled?: boolean;\n  clusteringLevel?: number;\n  fadeEnabled?: boolean;\n  fadeOpacityEnabled?: boolean;\n  clusteringAuto?: boolean;\n  darkMode?: boolean;\n  fadeAmount?: number;\n  colorScheme?: string | string[];\n  highlightColor?: string | number[];\n  maxTopFlowsDisplayNum?: number;\n  onHover?: (\n    info: FlowmapLayerPickingInfo<L, F> | undefined,\n    event: SourceEvent,\n  ) => void;\n  onClick?: (info: FlowmapLayerPickingInfo<L, F>, event: SourceEvent) => void;\n} & Partial<FlowmapDataAccessors<L, F>> &\n  LayerProps;\n\nconst PROPS_TO_CAUSE_LAYER_DATA_UPDATE: string[] = [\n  'filter',\n  'locationTotalsEnabled',\n  'locationLabelsEnabled',\n  'adaptiveScalesEnabled',\n  'animationEnabled',\n  'clusteringEnabled',\n  'clusteringLevel',\n  'fadeEnabled',\n  'fadeOpacityEnabled',\n  'clusteringAuto',\n  'darkMode',\n  'fadeAmount',\n  'colorScheme',\n  'highlightColor',\n  'maxTopFlowsDisplayNum',\n];\n\nenum HighlightType {\n  LOCATION = 'location',\n  FLOW = 'flow',\n}\n\ntype HighlightedLocationObject = {\n  type: HighlightType.LOCATION;\n  coords: [number, number];\n  radius: number;\n};\n\ntype HighlightedFlowObject = {\n  type: HighlightType.FLOW;\n  lineAttributes: FlowLinesLayerAttributes;\n};\n\ntype HighlightedObject = HighlightedLocationObject | HighlightedFlowObject;\n\ntype State<L, F> = {\n  accessors: FlowmapAggregateAccessors<L, F>;\n  dataProvider: FlowmapDataProvider<L, F>;\n  layersData: LayersData | undefined;\n  highlightedObject: HighlightedObject | undefined;\n  pickingInfo: FlowmapLayerPickingInfo<L, F> | undefined;\n  lastHoverTime: number | undefined;\n  lastClickTime: number | undefined;\n};\n\nexport type SourceEvent = {srcEvent: MouseEvent};\n\nexport default class FlowmapLayer<L, F> extends CompositeLayer {\n  static defaultProps = {\n    darkMode: true,\n    fadeAmount: 50,\n    locationTotalsEnabled: true,\n    locationLabelsEnabled: false,\n    animationEnabled: false,\n    clusteringEnabled: true,\n    fadeEnabled: true,\n    fadeOpacityEnabled: false,\n    clusteringAuto: true,\n    clusteringLevel: undefined,\n    adaptiveScalesEnabled: true,\n    colorScheme: 'Teal',\n    highlightColor: 'orange',\n    maxTopFlowsDisplayNum: 5000,\n  };\n  state: State<L, F> | undefined;\n\n  public constructor(props: FlowmapLayerProps<L, F>) {\n    super({\n      ...props,\n      onHover: (info: PickingInfo<any>, event: SourceEvent) => {\n        const startTime = Date.now();\n        this.setState({\n          highlightedObject: this._getHighlightedObject(info),\n          lastHoverTime: startTime,\n        });\n\n        const {onHover} = props;\n        if (onHover) {\n          this._getFlowmapLayerPickingInfo(info).then((info) => {\n            if ((this.state?.lastHoverTime ?? 0) <= startTime) {\n              this.setState({pickingInfo: info});\n              onHover(info, event);\n            } else {\n              // Skipping, because this is not the latest hover event\n            }\n          });\n        }\n      },\n      onClick: (info: PickingInfo<any>, event: SourceEvent) => {\n        const {onClick} = props;\n        const startTime = Date.now();\n        this.setState({\n          lastClickTime: startTime,\n        });\n        if (onClick) {\n          this._getFlowmapLayerPickingInfo(info).then((info) => {\n            if ((this.state?.lastClickTime ?? 0) <= startTime) {\n              this.setState({pickingInfo: info});\n              if (info) {\n                onClick(info, event);\n              }\n            } else {\n              // Skipping, because this is not the latest hover event\n            }\n          });\n        }\n      },\n    });\n  }\n\n  initializeState() {\n    this.state = {\n      accessors: new FlowmapAggregateAccessors<L, F>(this.props),\n      dataProvider: this._getOrMakeDataProvider(),\n      layersData: undefined,\n      highlightedObject: undefined,\n      pickingInfo: undefined,\n      lastHoverTime: undefined,\n      lastClickTime: undefined,\n    };\n  }\n\n  getPickingInfo({info}: Record<string, any>) {\n    // This is for onHover event handlers set on the <DeckGL> component\n    if (!info.object) {\n      const object = this.state?.pickingInfo?.object;\n      if (object) {\n        return {\n          ...info,\n          object,\n          picked: true,\n        };\n      }\n    }\n    return info;\n  }\n\n  // private _updateAccessors() {\n  //   this.state?.dataProvider?.setAccessors(this.props);\n  //   this.setState({accessors: new FlowmapAggregateAccessors(this.props)});\n  // }\n\n  private _getOrMakeDataProvider() {\n    const {data, dataProvider} = this.props;\n    if (isFlowmapDataProvider<L, F>(dataProvider)) {\n      return dataProvider;\n    } else if (isFlowmapData<L, F>(data)) {\n      const dataProvider = new LocalFlowmapDataProvider<L, F>(this.props);\n      dataProvider.setFlowmapData(data);\n      return dataProvider;\n    }\n    throw new Error(\n      'FlowmapLayer: data must be a FlowmapDataProvider or FlowmapData',\n    );\n  }\n\n  private _updateDataProvider() {\n    this.setState({dataProvider: this._getOrMakeDataProvider()});\n  }\n\n  shouldUpdateState(params: Record<string, any>): boolean {\n    const {changeFlags} = params;\n    // if (this._viewportChanged()) {\n    //   return true;\n    // }\n    if (changeFlags.viewportChanged) {\n      return true;\n    }\n    return super.shouldUpdateState(params);\n    // TODO: be smarter on when to update\n    // (e.g. ignore viewport changes when adaptiveScalesEnabled and clustering are false)\n  }\n\n  updateState({oldProps, props, changeFlags}: Record<string, any>): void {\n    if (changeFlags.propsChanged) {\n      // this._updateAccessors();\n    }\n    if (changeFlags.dataChanged) {\n      this._updateDataProvider();\n    }\n    if (changeFlags.viewportChanged || changeFlags.dataChanged) {\n      this.setState({highlightedObject: undefined});\n    }\n\n    if (\n      changeFlags.viewportChanged ||\n      changeFlags.dataChanged ||\n      (changeFlags.propsChanged &&\n        PROPS_TO_CAUSE_LAYER_DATA_UPDATE.some(\n          (prop) => oldProps[prop] !== props[prop],\n        ))\n    ) {\n      const {dataProvider} = this.state || {};\n      if (dataProvider) {\n        dataProvider.setFlowmapState(this._getFlowmapState());\n        dataProvider.updateLayersData((layersData: LayersData | undefined) => {\n          this.setState({layersData, highlightedObject: undefined});\n        }, changeFlags);\n      }\n    }\n  }\n\n  private _getSettingsState() {\n    const {\n      locationTotalsEnabled,\n      locationLabelsEnabled,\n      adaptiveScalesEnabled,\n      animationEnabled,\n      clusteringEnabled,\n      clusteringLevel,\n      fadeEnabled,\n      fadeOpacityEnabled,\n      clusteringAuto,\n      darkMode,\n      fadeAmount,\n      colorScheme,\n      highlightColor,\n      maxTopFlowsDisplayNum,\n    } = this.props;\n    return {\n      locationTotalsEnabled,\n      locationLabelsEnabled,\n      adaptiveScalesEnabled,\n      animationEnabled,\n      clusteringEnabled,\n      clusteringLevel,\n      fadeEnabled,\n      fadeOpacityEnabled,\n      clusteringAuto,\n      darkMode,\n      fadeAmount,\n      colorScheme,\n      highlightColor,\n      maxTopFlowsDisplayNum,\n    };\n  }\n\n  private _getFlowmapState() {\n    return {\n      viewport: pickViewportProps(this.context.viewport),\n      filter: this.props.filter,\n      settings: this._getSettingsState(),\n    };\n  }\n\n  private async _getFlowmapLayerPickingInfo(\n    info: Record<string, any>,\n  ): Promise<FlowmapLayerPickingInfo<L, F> | undefined> {\n    const {index, sourceLayer} = info;\n    const {dataProvider, accessors} = this.state || {};\n    if (!dataProvider || !accessors) {\n      return undefined;\n    }\n    const commonInfo = {\n      ...info,\n      picked: info.picked,\n      layer: info.layer,\n      index: info.index,\n      x: info.x,\n      y: info.y,\n      coordinate: info.coordinate,\n      event: info.event,\n    };\n    if (\n      sourceLayer instanceof FlowLinesLayer ||\n      sourceLayer instanceof AnimatedFlowLinesLayer\n    ) {\n      const flow =\n        index === -1 ? undefined : await dataProvider.getFlowByIndex(index);\n      if (flow) {\n        const origin = await dataProvider.getLocationById(\n          accessors.getFlowOriginId(flow),\n        );\n        const dest = await dataProvider.getLocationById(\n          accessors.getFlowDestId(flow),\n        );\n        if (origin && dest) {\n          return {\n            ...commonInfo,\n            object: {\n              type: PickingType.FLOW,\n              flow,\n              origin: origin,\n              dest: dest,\n              count: accessors.getFlowMagnitude(flow),\n            },\n          };\n        }\n      }\n    } else if (sourceLayer instanceof FlowCirclesLayer) {\n      const location =\n        index === -1 ? undefined : await dataProvider.getLocationByIndex(index);\n\n      if (location) {\n        const id = accessors.getLocationId(location);\n        const name = accessors.getLocationName(location);\n        const totals = await dataProvider.getTotalsForLocation(id);\n        const {circleAttributes} = this.state?.layersData || {};\n        if (totals && circleAttributes) {\n          const circleRadius = getOuterCircleRadiusByIndex(\n            circleAttributes,\n            info.index,\n          );\n          return {\n            ...commonInfo,\n            object: {\n              type: PickingType.LOCATION,\n              location,\n              id,\n              name,\n              totals,\n              circleRadius: circleRadius,\n            },\n          };\n        }\n      }\n    }\n\n    return undefined;\n  }\n\n  private _getHighlightedObject(\n    info: Record<string, any>,\n  ): HighlightedObject | undefined {\n    const {index, sourceLayer} = info;\n    if (index < 0) return undefined;\n    if (\n      sourceLayer instanceof FlowLinesLayer ||\n      sourceLayer instanceof AnimatedFlowLinesLayer\n    ) {\n      const {lineAttributes} = this.state?.layersData || {};\n      if (lineAttributes) {\n        let attrs = getFlowLineAttributesByIndex(lineAttributes, index);\n        if (this.props.fadeOpacityEnabled) {\n          attrs = {\n            ...attrs,\n            attributes: {\n              ...attrs.attributes,\n              getColor: {\n                ...attrs.attributes.getColor,\n                value: new Uint8Array([\n                  ...attrs.attributes.getColor.value.slice(0, 3),\n                  255, // the highlight color should be always opaque\n                ]),\n              },\n            },\n          };\n        }\n        return {\n          type: HighlightType.FLOW,\n          lineAttributes: attrs,\n        };\n      }\n    } else if (sourceLayer instanceof FlowCirclesLayer) {\n      const {circleAttributes} = this.state?.layersData || {};\n      if (circleAttributes) {\n        return {\n          type: HighlightType.LOCATION,\n          coords: getLocationCoordsByIndex(circleAttributes, index),\n          radius: getOuterCircleRadiusByIndex(circleAttributes, index),\n        };\n      }\n    }\n    return undefined;\n  }\n\n  renderLayers(): Array<any> {\n    const layers = [];\n    if (this.state?.layersData) {\n      const {layersData, highlightedObject} = this.state;\n      const {circleAttributes, lineAttributes, locationLabels} =\n        layersData || {};\n      if (circleAttributes && lineAttributes) {\n        const flowmapColors = getFlowmapColors(this._getSettingsState());\n        const outlineColor = colorAsRgba(\n          flowmapColors.outlineColor || (this.props.darkMode ? '#000' : '#fff'),\n        );\n        const commonLineLayerProps = {\n          data: lineAttributes,\n          parameters: {\n            ...this.props.parameters,\n            // prevent z-fighting at non-zero bearing/pitch\n            depthTest: false,\n          },\n        };\n        if (this.props.animationEnabled) {\n          layers.push(\n            // @ts-ignore\n            new AnimatedFlowLinesLayer({\n              ...this.getSubLayerProps({\n                ...commonLineLayerProps,\n                id: 'animated-flow-lines',\n                drawOutline: false,\n                thicknessUnit: 20,\n              }),\n            }),\n          );\n        } else {\n          layers.push(\n            new FlowLinesLayer({\n              ...this.getSubLayerProps({\n                ...commonLineLayerProps,\n                id: 'flow-lines',\n                drawOutline: true,\n                outlineColor: outlineColor,\n              }),\n            }),\n          );\n        }\n        layers.push(\n          new FlowCirclesLayer(\n            this.getSubLayerProps({\n              id: 'circles',\n              data: circleAttributes,\n              emptyColor: this.props.darkMode\n                ? [0, 0, 0, 255]\n                : [255, 255, 255, 255],\n              outlineEmptyMix: 0.4,\n            }),\n          ),\n        );\n        if (highlightedObject) {\n          switch (highlightedObject.type) {\n            case HighlightType.LOCATION:\n              layers.push(\n                new ScatterplotLayer({\n                  ...this.getSubLayerProps({\n                    id: 'location-highlight',\n                    data: [highlightedObject],\n                    pickable: false,\n                    antialiasing: true,\n                    stroked: true,\n                    filled: false,\n                    lineWidthUnits: 'pixels',\n                    getLineWidth: 2,\n                    radiusUnits: 'pixels',\n                    getRadius: (d: HighlightedLocationObject) => d.radius,\n                    getLineColor: colorAsRgba(this.props.highlightColor),\n                    getPosition: (d: HighlightedLocationObject) => d.coords,\n                  }),\n                }),\n              );\n              break;\n            case HighlightType.FLOW:\n              layers.push(\n                new FlowLinesLayer({\n                  ...this.getSubLayerProps({\n                    id: 'flow-highlight',\n                    data: highlightedObject.lineAttributes,\n                    drawOutline: true,\n                    pickable: false,\n                    outlineColor: colorAsRgba(this.props.highlightColor),\n                    outlineThickness: 1,\n                    parameters: {\n                      depthTest: false,\n                    },\n                  }),\n                }),\n              );\n              break;\n          }\n        }\n      }\n      if (locationLabels) {\n        layers.push(\n          new TextLayer(\n            this.getSubLayerProps({\n              id: 'location-labels',\n              data: locationLabels,\n              maxWidth: 1000,\n              pickable: false,\n              fontFamily: 'Helvetica',\n              getPixelOffset: (d: string, {index}: {index: number}) => {\n                const r = getOuterCircleRadiusByIndex(circleAttributes, index);\n                return [0, r + 5];\n              },\n              getPosition: (d: string, {index}: {index: number}) => {\n                const pos = getLocationCoordsByIndex(circleAttributes, index);\n                return pos;\n              },\n              getText: (d: string) => d,\n              getSize: 10,\n              getColor: [255, 255, 255, 255],\n              getAngle: 0,\n              getTextAnchor: 'middle',\n              getAlignmentBaseline: 'top',\n            }),\n          ),\n        );\n      }\n    }\n\n    return layers;\n  }\n}\n\nfunction pickViewportProps(viewport: Record<string, any>): ViewportProps {\n  const {width, height, longitude, latitude, zoom, pitch, bearing} = viewport;\n  return {\n    width,\n    height,\n    longitude,\n    latitude,\n    zoom,\n    pitch,\n    bearing,\n  };\n}\n"]}
|
|
431
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FlowmapLayer.js","sourceRoot":"","sources":["../src/FlowmapLayer.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) Flowmap.gl contributors\n * Copyright (c) 2018-2020 Teralytics\n * SPDX-License-Identifier: Apache-2.0\n */\nimport {CompositeLayer} from '@deck.gl/core';\nimport {ScatterplotLayer, TextLayer} from '@deck.gl/layers';\nimport {\n  colorAsRgba,\n  FilterState,\n  FlowLinesLayerAttributes,\n  FlowmapAggregateAccessors,\n  FlowmapData,\n  FlowmapDataAccessors,\n  FlowmapDataProvider,\n  getFlowLineAttributesByIndex,\n  getFlowmapColors,\n  getLocationCoordsByIndex,\n  getOuterCircleRadiusByIndex,\n  isFlowmapData,\n  isFlowmapDataProvider,\n  LayersData,\n  LocalFlowmapDataProvider,\n  ViewportProps,\n} from '@flowmap.gl/data';\nimport AnimatedFlowLinesLayer from './AnimatedFlowLinesLayer';\nimport FlowCirclesLayer from './FlowCirclesLayer';\nimport FlowLinesLayer from './FlowLinesLayer';\nimport {\n  FlowmapLayerPickingInfo,\n  LayerProps,\n  PickingInfo,\n  PickingType,\n} from './types';\n\nexport type FlowmapLayerProps<\n  L extends Record<string, any>,\n  F extends Record<string, any>,\n> = {\n  data?: FlowmapData<L, F>;\n  dataProvider?: FlowmapDataProvider<L, F>;\n  filter?: FilterState;\n  locationsEnabled?: boolean;\n  locationTotalsEnabled?: boolean;\n  locationLabelsEnabled?: boolean;\n  adaptiveScalesEnabled?: boolean;\n  animationEnabled?: boolean;\n  clusteringEnabled?: boolean;\n  clusteringLevel?: number;\n  fadeEnabled?: boolean;\n  fadeOpacityEnabled?: boolean;\n  clusteringAuto?: boolean;\n  darkMode?: boolean;\n  fadeAmount?: number;\n  colorScheme?: string | string[];\n  highlightColor?: string | number[];\n  maxTopFlowsDisplayNum?: number;\n  onHover?: (\n    info: FlowmapLayerPickingInfo<L, F> | undefined,\n    event: SourceEvent,\n  ) => void;\n  onClick?: (info: FlowmapLayerPickingInfo<L, F>, event: SourceEvent) => void;\n} & Partial<FlowmapDataAccessors<L, F>> &\n  LayerProps;\n\nconst PROPS_TO_CAUSE_LAYER_DATA_UPDATE: string[] = [\n  'filter',\n  'locationsEnabled',\n  'locationTotalsEnabled',\n  'locationLabelsEnabled',\n  'adaptiveScalesEnabled',\n  'animationEnabled',\n  'clusteringEnabled',\n  'clusteringLevel',\n  'fadeEnabled',\n  'fadeOpacityEnabled',\n  'clusteringAuto',\n  'darkMode',\n  'fadeAmount',\n  'colorScheme',\n  'highlightColor',\n  'maxTopFlowsDisplayNum',\n];\n\nenum HighlightType {\n  LOCATION = 'location',\n  FLOW = 'flow',\n}\n\ntype HighlightedLocationObject = {\n  type: HighlightType.LOCATION;\n  coords: [number, number];\n  radius: number;\n};\n\ntype HighlightedFlowObject = {\n  type: HighlightType.FLOW;\n  lineAttributes: FlowLinesLayerAttributes;\n};\n\ntype HighlightedObject = HighlightedLocationObject | HighlightedFlowObject;\n\ntype State<L extends Record<string, any>, F extends Record<string, any>> = {\n  accessors: FlowmapAggregateAccessors<L, F>;\n  dataProvider: FlowmapDataProvider<L, F>;\n  layersData: LayersData | undefined;\n  highlightedObject: HighlightedObject | undefined;\n  pickingInfo: FlowmapLayerPickingInfo<L, F> | undefined;\n  lastHoverTime: number | undefined;\n  lastClickTime: number | undefined;\n};\n\nexport type SourceEvent = {srcEvent: MouseEvent};\n\nexport default class FlowmapLayer<\n  L extends Record<string, any>,\n  F extends Record<string, any>,\n> extends CompositeLayer {\n  static defaultProps = {\n    darkMode: true,\n    fadeAmount: 50,\n    locationsEnabled: true,\n    locationTotalsEnabled: true,\n    locationLabelsEnabled: false,\n    animationEnabled: false,\n    clusteringEnabled: true,\n    fadeEnabled: true,\n    fadeOpacityEnabled: false,\n    clusteringAuto: true,\n    clusteringLevel: undefined,\n    adaptiveScalesEnabled: true,\n    colorScheme: 'Teal',\n    highlightColor: 'orange',\n    maxTopFlowsDisplayNum: 5000,\n  };\n  state: State<L, F> | undefined;\n\n  public constructor(props: FlowmapLayerProps<L, F>) {\n    super({\n      ...props,\n      onHover: (info: PickingInfo<any>, event: SourceEvent) => {\n        const startTime = Date.now();\n        this.setState({\n          highlightedObject: this._getHighlightedObject(info),\n          lastHoverTime: startTime,\n        });\n\n        const {onHover} = props;\n        if (onHover) {\n          this._getFlowmapLayerPickingInfo(info).then((info) => {\n            if ((this.state?.lastHoverTime ?? 0) <= startTime) {\n              this.setState({pickingInfo: info});\n              onHover(info, event);\n            } else {\n              // Skipping, because this is not the latest hover event\n            }\n          });\n        }\n      },\n      onClick: (info: PickingInfo<any>, event: SourceEvent) => {\n        const {onClick} = props;\n        const startTime = Date.now();\n        this.setState({\n          lastClickTime: startTime,\n        });\n        if (onClick) {\n          this._getFlowmapLayerPickingInfo(info).then((info) => {\n            if ((this.state?.lastClickTime ?? 0) <= startTime) {\n              this.setState({pickingInfo: info});\n              if (info) {\n                onClick(info, event);\n              }\n            } else {\n              // Skipping, because this is not the latest hover event\n            }\n          });\n        }\n      },\n    });\n  }\n\n  initializeState() {\n    this.state = {\n      accessors: new FlowmapAggregateAccessors<L, F>(this.props),\n      dataProvider: this._getOrMakeDataProvider(),\n      layersData: undefined,\n      highlightedObject: undefined,\n      pickingInfo: undefined,\n      lastHoverTime: undefined,\n      lastClickTime: undefined,\n    };\n  }\n\n  getPickingInfo({info}: Record<string, any>) {\n    // This is for onHover event handlers set on the <DeckGL> component\n    if (!info.object) {\n      const object = this.state?.pickingInfo?.object;\n      if (object) {\n        return {\n          ...info,\n          object,\n          picked: true,\n        };\n      }\n    }\n    return info;\n  }\n\n  // private _updateAccessors() {\n  //   this.state?.dataProvider?.setAccessors(this.props);\n  //   this.setState({accessors: new FlowmapAggregateAccessors(this.props)});\n  // }\n\n  private _getOrMakeDataProvider() {\n    const {data, dataProvider} = this.props;\n    if (isFlowmapDataProvider<L, F>(dataProvider)) {\n      return dataProvider;\n    } else if (isFlowmapData<L, F>(data)) {\n      const dataProvider = new LocalFlowmapDataProvider<L, F>(this.props);\n      dataProvider.setFlowmapData(data);\n      return dataProvider;\n    }\n    throw new Error(\n      'FlowmapLayer: data must be a FlowmapDataProvider or FlowmapData',\n    );\n  }\n\n  private _updateDataProvider() {\n    this.setState({dataProvider: this._getOrMakeDataProvider()});\n  }\n\n  shouldUpdateState(params: Record<string, any>): boolean {\n    const {changeFlags} = params;\n    // if (this._viewportChanged()) {\n    //   return true;\n    // }\n    if (changeFlags.viewportChanged) {\n      return true;\n    }\n    return super.shouldUpdateState(params);\n    // TODO: be smarter on when to update\n    // (e.g. ignore viewport changes when adaptiveScalesEnabled and clustering are false)\n  }\n\n  updateState({oldProps, props, changeFlags}: Record<string, any>): void {\n    if (changeFlags.propsChanged) {\n      // this._updateAccessors();\n    }\n    if (changeFlags.dataChanged) {\n      this._updateDataProvider();\n    }\n    if (changeFlags.viewportChanged || changeFlags.dataChanged) {\n      this.setState({highlightedObject: undefined});\n    }\n\n    if (\n      changeFlags.viewportChanged ||\n      changeFlags.dataChanged ||\n      (changeFlags.propsChanged &&\n        PROPS_TO_CAUSE_LAYER_DATA_UPDATE.some(\n          (prop) => oldProps[prop] !== props[prop],\n        ))\n    ) {\n      const {dataProvider} = this.state || {};\n      if (dataProvider) {\n        dataProvider.setFlowmapState(this._getFlowmapState());\n        dataProvider.updateLayersData((layersData: LayersData | undefined) => {\n          this.setState({layersData, highlightedObject: undefined});\n        }, changeFlags);\n      }\n    }\n  }\n\n  private _getSettingsState() {\n    const {\n      locationsEnabled,\n      locationTotalsEnabled,\n      locationLabelsEnabled,\n      adaptiveScalesEnabled,\n      animationEnabled,\n      clusteringEnabled,\n      clusteringLevel,\n      fadeEnabled,\n      fadeOpacityEnabled,\n      clusteringAuto,\n      darkMode,\n      fadeAmount,\n      colorScheme,\n      highlightColor,\n      maxTopFlowsDisplayNum,\n    } = this.props;\n    return {\n      locationsEnabled,\n      locationTotalsEnabled,\n      locationLabelsEnabled,\n      adaptiveScalesEnabled,\n      animationEnabled,\n      clusteringEnabled,\n      clusteringLevel,\n      fadeEnabled,\n      fadeOpacityEnabled,\n      clusteringAuto,\n      darkMode,\n      fadeAmount,\n      colorScheme,\n      highlightColor,\n      maxTopFlowsDisplayNum,\n    };\n  }\n\n  private _getFlowmapState() {\n    return {\n      viewport: pickViewportProps(this.context.viewport),\n      filter: this.props.filter,\n      settings: this._getSettingsState(),\n    };\n  }\n\n  private async _getFlowmapLayerPickingInfo(\n    info: Record<string, any>,\n  ): Promise<FlowmapLayerPickingInfo<L, F> | undefined> {\n    const {index, sourceLayer} = info;\n    const {dataProvider, accessors} = this.state || {};\n    if (!dataProvider || !accessors) {\n      return undefined;\n    }\n    const commonInfo = {\n      ...info,\n      picked: info.picked,\n      layer: info.layer,\n      index: info.index,\n      x: info.x,\n      y: info.y,\n      coordinate: info.coordinate,\n      event: info.event,\n    };\n    if (\n      sourceLayer instanceof FlowLinesLayer ||\n      sourceLayer instanceof AnimatedFlowLinesLayer\n    ) {\n      const flow =\n        index === -1 ? undefined : await dataProvider.getFlowByIndex(index);\n      if (flow) {\n        const origin = await dataProvider.getLocationById(\n          accessors.getFlowOriginId(flow),\n        );\n        const dest = await dataProvider.getLocationById(\n          accessors.getFlowDestId(flow),\n        );\n        if (origin && dest) {\n          return {\n            ...commonInfo,\n            object: {\n              type: PickingType.FLOW,\n              flow,\n              origin: origin,\n              dest: dest,\n              count: accessors.getFlowMagnitude(flow),\n            },\n          };\n        }\n      }\n    } else if (sourceLayer instanceof FlowCirclesLayer) {\n      const location =\n        index === -1 ? undefined : await dataProvider.getLocationByIndex(index);\n\n      if (location) {\n        const id = accessors.getLocationId(location);\n        const name = accessors.getLocationName(location);\n        const totals = await dataProvider.getTotalsForLocation(id);\n        const {circleAttributes} = this.state?.layersData || {};\n        if (totals && circleAttributes) {\n          const circleRadius = getOuterCircleRadiusByIndex(\n            circleAttributes,\n            info.index,\n          );\n          return {\n            ...commonInfo,\n            object: {\n              type: PickingType.LOCATION,\n              location,\n              id,\n              name,\n              totals,\n              circleRadius: circleRadius,\n            },\n          };\n        }\n      }\n    }\n\n    return undefined;\n  }\n\n  private _getHighlightedObject(\n    info: Record<string, any>,\n  ): HighlightedObject | undefined {\n    const {index, sourceLayer} = info;\n    if (index < 0) return undefined;\n    if (\n      sourceLayer instanceof FlowLinesLayer ||\n      sourceLayer instanceof AnimatedFlowLinesLayer\n    ) {\n      const {lineAttributes} = this.state?.layersData || {};\n      if (lineAttributes) {\n        let attrs = getFlowLineAttributesByIndex(lineAttributes, index);\n        if (this.props.fadeOpacityEnabled) {\n          attrs = {\n            ...attrs,\n            attributes: {\n              ...attrs.attributes,\n              getColor: {\n                ...attrs.attributes.getColor,\n                value: new Uint8Array([\n                  ...attrs.attributes.getColor.value.slice(0, 3),\n                  255, // the highlight color should be always opaque\n                ]),\n              },\n            },\n          };\n        }\n        return {\n          type: HighlightType.FLOW,\n          lineAttributes: attrs,\n        };\n      }\n    } else if (sourceLayer instanceof FlowCirclesLayer) {\n      const {circleAttributes} = this.state?.layersData || {};\n      if (circleAttributes) {\n        return {\n          type: HighlightType.LOCATION,\n          coords: getLocationCoordsByIndex(circleAttributes, index),\n          radius: getOuterCircleRadiusByIndex(circleAttributes, index),\n        };\n      }\n    }\n    return undefined;\n  }\n\n  renderLayers(): Array<any> {\n    const layers = [];\n    if (this.state?.layersData) {\n      const {layersData, highlightedObject} = this.state;\n      const {circleAttributes, lineAttributes, locationLabels} =\n        layersData || {};\n      if (circleAttributes && lineAttributes) {\n        const flowmapColors = getFlowmapColors(this._getSettingsState());\n        const outlineColor = colorAsRgba(\n          flowmapColors.outlineColor || (this.props.darkMode ? '#000' : '#fff'),\n        );\n        const commonLineLayerProps = {\n          data: lineAttributes,\n          parameters: {\n            ...this.props.parameters,\n            // prevent z-fighting at non-zero bearing/pitch\n            depthTest: false,\n          },\n        };\n        if (this.props.animationEnabled) {\n          layers.push(\n            // @ts-ignore\n            new AnimatedFlowLinesLayer({\n              ...this.getSubLayerProps({\n                ...commonLineLayerProps,\n                id: 'animated-flow-lines',\n                drawOutline: false,\n                thicknessUnit: 20,\n              }),\n            }),\n          );\n        } else {\n          layers.push(\n            new FlowLinesLayer({\n              ...this.getSubLayerProps({\n                ...commonLineLayerProps,\n                id: 'flow-lines',\n                drawOutline: true,\n                outlineColor: outlineColor,\n              }),\n            }),\n          );\n        }\n        layers.push(\n          new FlowCirclesLayer(\n            this.getSubLayerProps({\n              id: 'circles',\n              data: circleAttributes,\n              emptyColor: this.props.darkMode\n                ? [0, 0, 0, 255]\n                : [255, 255, 255, 255],\n              outlineEmptyMix: 0.4,\n            }),\n          ),\n        );\n        if (highlightedObject) {\n          switch (highlightedObject.type) {\n            case HighlightType.LOCATION:\n              layers.push(\n                new ScatterplotLayer({\n                  ...this.getSubLayerProps({\n                    id: 'location-highlight',\n                    data: [highlightedObject],\n                    pickable: false,\n                    antialiasing: true,\n                    stroked: true,\n                    filled: false,\n                    lineWidthUnits: 'pixels',\n                    getLineWidth: 2,\n                    radiusUnits: 'pixels',\n                    getRadius: (d: HighlightedLocationObject) => d.radius,\n                    getLineColor: colorAsRgba(this.props.highlightColor),\n                    getPosition: (d: HighlightedLocationObject) => d.coords,\n                  }),\n                }),\n              );\n              break;\n            case HighlightType.FLOW:\n              layers.push(\n                new FlowLinesLayer({\n                  ...this.getSubLayerProps({\n                    id: 'flow-highlight',\n                    data: highlightedObject.lineAttributes,\n                    drawOutline: true,\n                    pickable: false,\n                    outlineColor: colorAsRgba(this.props.highlightColor),\n                    outlineThickness: 1,\n                    parameters: {\n                      depthTest: false,\n                    },\n                  }),\n                }),\n              );\n              break;\n          }\n        }\n      }\n      if (locationLabels) {\n        layers.push(\n          new TextLayer(\n            this.getSubLayerProps({\n              id: 'location-labels',\n              data: locationLabels,\n              maxWidth: 1000,\n              pickable: false,\n              fontFamily: 'Helvetica',\n              getPixelOffset: (d: string, {index}: {index: number}) => {\n                const r = getOuterCircleRadiusByIndex(circleAttributes, index);\n                return [0, r + 5];\n              },\n              getPosition: (d: string, {index}: {index: number}) => {\n                const pos = getLocationCoordsByIndex(circleAttributes, index);\n                return pos;\n              },\n              getText: (d: string) => d,\n              getSize: 10,\n              getColor: [255, 255, 255, 255],\n              getAngle: 0,\n              getTextAnchor: 'middle',\n              getAlignmentBaseline: 'top',\n            }),\n          ),\n        );\n      }\n    }\n\n    return layers;\n  }\n}\n\nfunction pickViewportProps(viewport: Record<string, any>): ViewportProps {\n  const {width, height, longitude, latitude, zoom, pitch, bearing} = viewport;\n  return {\n    width,\n    height,\n    longitude,\n    latitude,\n    zoom,\n    pitch,\n    bearing,\n  };\n}\n"]}
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAMA,OAAO,EAAC,OAAO,IAAI,sBAAsB,EAAC,MAAM,0BAA0B,CAAC;AAC3E,OAAO,EAAC,OAAO,IAAI,cAAc,EAAC,MAAM,kBAAkB,CAAC;AAC3D,OAAO,EAAC,OAAO,IAAI,gBAAgB,EAAC,MAAM,oBAAoB,CAAC;AAC/D,OAAO,EAAC,OAAO,IAAI,YAAY,EAAC,MAAM,gBAAgB,CAAC;AACvD,YAAY,EAAC,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;AAEtD,cAAc,SAAS,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,6 +1,11 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) Flowmap.gl contributors
|
|
3
|
+
* Copyright (c) 2018-2020 Teralytics
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
1
6
|
export { default as AnimatedFlowLinesLayer } from './AnimatedFlowLinesLayer';
|
|
2
7
|
export { default as FlowLinesLayer } from './FlowLinesLayer';
|
|
3
8
|
export { default as FlowCirclesLayer } from './FlowCirclesLayer';
|
|
4
9
|
export { default as FlowmapLayer } from './FlowmapLayer';
|
|
5
10
|
export * from './types';
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUVILE9BQU8sRUFBQyxPQUFPLElBQUksc0JBQXNCLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRSxPQUFPLEVBQUMsT0FBTyxJQUFJLGNBQWMsRUFBQyxNQUFNLGtCQUFrQixDQUFDO0FBQzNELE9BQU8sRUFBQyxPQUFPLElBQUksZ0JBQWdCLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQztBQUMvRCxPQUFPLEVBQUMsT0FBTyxJQUFJLFlBQVksRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBR3ZELGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgRmxvd21hcC5nbCBjb250cmlidXRvcnNcbiAqIENvcHlyaWdodCAoYykgMjAxOC0yMDIwIFRlcmFseXRpY3NcbiAqIFNQRFgtTGljZW5zZS1JZGVudGlmaWVyOiBBcGFjaGUtMi4wXG4gKi9cblxuZXhwb3J0IHtkZWZhdWx0IGFzIEFuaW1hdGVkRmxvd0xpbmVzTGF5ZXJ9IGZyb20gJy4vQW5pbWF0ZWRGbG93TGluZXNMYXllcic7XG5leHBvcnQge2RlZmF1bHQgYXMgRmxvd0xpbmVzTGF5ZXJ9IGZyb20gJy4vRmxvd0xpbmVzTGF5ZXInO1xuZXhwb3J0IHtkZWZhdWx0IGFzIEZsb3dDaXJjbGVzTGF5ZXJ9IGZyb20gJy4vRmxvd0NpcmNsZXNMYXllcic7XG5leHBvcnQge2RlZmF1bHQgYXMgRmxvd21hcExheWVyfSBmcm9tICcuL0Zsb3dtYXBMYXllcic7XG5leHBvcnQgdHlwZSB7Rmxvd21hcExheWVyUHJvcHN9IGZyb20gJy4vRmxvd21hcExheWVyJztcblxuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG4iXX0=
|
package/dist/types.d.ts
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { AggregateFlow, ClusterNode, LocationTotals } from '@flowmap.gl/data';
|
|
2
|
-
export
|
|
2
|
+
export type LayerProps = Record<string, unknown>;
|
|
3
3
|
export declare enum PickingType {
|
|
4
4
|
LOCATION = "location",
|
|
5
5
|
FLOW = "flow"
|
|
6
6
|
}
|
|
7
|
-
export
|
|
7
|
+
export type DeckGLLayer = Record<string, any>;
|
|
8
8
|
export interface PickingInfo<T> {
|
|
9
9
|
layer: DeckGLLayer;
|
|
10
10
|
index: number;
|
|
@@ -23,7 +23,7 @@ export interface LocationPickingInfoObject<L> {
|
|
|
23
23
|
totals: LocationTotals;
|
|
24
24
|
circleRadius: number;
|
|
25
25
|
}
|
|
26
|
-
export
|
|
26
|
+
export type LocationPickingInfo<L> = PickingInfo<LocationPickingInfoObject<L>>;
|
|
27
27
|
export interface FlowPickingInfoObject<L, F> {
|
|
28
28
|
type: PickingType.FLOW;
|
|
29
29
|
flow: F | AggregateFlow;
|
|
@@ -31,6 +31,6 @@ export interface FlowPickingInfoObject<L, F> {
|
|
|
31
31
|
dest: L | ClusterNode;
|
|
32
32
|
count: number;
|
|
33
33
|
}
|
|
34
|
-
export
|
|
35
|
-
export
|
|
34
|
+
export type FlowPickingInfo<L, F> = PickingInfo<FlowPickingInfoObject<L, F>>;
|
|
35
|
+
export type FlowmapLayerPickingInfo<L, F> = LocationPickingInfo<L> | FlowPickingInfo<L, F>;
|
|
36
36
|
//# sourceMappingURL=types.d.ts.map
|