@flowmap.gl/layers 8.0.0-alpha.4 → 8.0.0-alpha.5
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/{FlowMapLayer.d.ts → FlowmapLayer.d.ts} +16 -14
- package/dist/FlowmapLayer.d.ts.map +1 -0
- package/dist/FlowmapLayer.js +323 -0
- package/dist/index.d.ts +2 -2
- package/dist/index.js +2 -2
- package/dist/types.d.ts +1 -1
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +1 -1
- package/package.json +2 -2
- package/src/{FlowMapLayer.ts → FlowmapLayer.ts} +39 -35
- package/src/index.ts +2 -2
- package/src/types.ts +1 -1
- package/dist/FlowMapLayer.d.ts.map +0 -1
- package/dist/FlowMapLayer.js +0 -320
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { CompositeLayer } from '@deck.gl/core';
|
|
2
|
-
import { FlowLinesLayerAttributes,
|
|
3
|
-
import {
|
|
4
|
-
export declare type
|
|
5
|
-
data:
|
|
2
|
+
import { FlowLinesLayerAttributes, FlowmapData, FlowmapDataAccessors, FlowmapDataProvider, LayersData, FlowmapAggregateAccessors } from '@flowmap.gl/data';
|
|
3
|
+
import { FlowmapLayerPickingInfo, LayerProps } from './types';
|
|
4
|
+
export declare type FlowmapLayerProps<L, F> = {
|
|
5
|
+
data: FlowmapData<L, F> | FlowmapDataProvider<L, F>;
|
|
6
6
|
locationTotalsEnabled?: boolean;
|
|
7
7
|
adaptiveScalesEnabled?: boolean;
|
|
8
8
|
animationEnabled?: boolean;
|
|
@@ -15,9 +15,10 @@ export declare type FlowMapLayerProps<L, F> = {
|
|
|
15
15
|
fadeAmount?: number;
|
|
16
16
|
colorScheme?: string;
|
|
17
17
|
highlightColor?: string;
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
18
|
+
maxTopFlowsDisplayNum?: number;
|
|
19
|
+
onHover?: (info: FlowmapLayerPickingInfo<L, F> | undefined, event: SourceEvent) => void;
|
|
20
|
+
onClick?: (info: FlowmapLayerPickingInfo<L, F>, event: SourceEvent) => void;
|
|
21
|
+
} & Partial<FlowmapDataAccessors<L, F>> & LayerProps;
|
|
21
22
|
declare enum HighlightType {
|
|
22
23
|
LOCATION = "location",
|
|
23
24
|
FLOW = "flow"
|
|
@@ -33,15 +34,15 @@ declare type HighlightedFlowObject = {
|
|
|
33
34
|
};
|
|
34
35
|
declare type HighlightedObject = HighlightedLocationObject | HighlightedFlowObject;
|
|
35
36
|
declare type State<L, F> = {
|
|
36
|
-
accessors:
|
|
37
|
-
dataProvider:
|
|
37
|
+
accessors: FlowmapAggregateAccessors<L, F>;
|
|
38
|
+
dataProvider: FlowmapDataProvider<L, F>;
|
|
38
39
|
layersData: LayersData | undefined;
|
|
39
40
|
highlightedObject: HighlightedObject | undefined;
|
|
40
41
|
};
|
|
41
42
|
export declare type SourceEvent = {
|
|
42
43
|
srcEvent: MouseEvent;
|
|
43
44
|
};
|
|
44
|
-
export default class
|
|
45
|
+
export default class FlowmapLayer<L, F> extends CompositeLayer {
|
|
45
46
|
static defaultProps: {
|
|
46
47
|
darkMode: boolean;
|
|
47
48
|
fadeAmount: number;
|
|
@@ -55,9 +56,10 @@ export default class FlowMapLayer<L, F> extends CompositeLayer {
|
|
|
55
56
|
adaptiveScalesEnabled: boolean;
|
|
56
57
|
colorScheme: string;
|
|
57
58
|
highlightColor: string;
|
|
59
|
+
maxTopFlowsDisplayNum: number;
|
|
58
60
|
};
|
|
59
61
|
state: State<L, F> | undefined;
|
|
60
|
-
constructor(props:
|
|
62
|
+
constructor(props: FlowmapLayerProps<L, F>);
|
|
61
63
|
initializeState(): void;
|
|
62
64
|
private _updateAccessors;
|
|
63
65
|
private _makeDataProvider;
|
|
@@ -65,10 +67,10 @@ export default class FlowMapLayer<L, F> extends CompositeLayer {
|
|
|
65
67
|
shouldUpdateState(params: Record<string, any>): boolean;
|
|
66
68
|
updateState({ oldProps, props, changeFlags }: Record<string, any>): void;
|
|
67
69
|
private _getSettingsState;
|
|
68
|
-
private
|
|
69
|
-
private
|
|
70
|
+
private _getFlowmapState;
|
|
71
|
+
private _getFlowmapLayerPickingInfo;
|
|
70
72
|
private _getHighlightedObject;
|
|
71
73
|
renderLayers(): Array<any>;
|
|
72
74
|
}
|
|
73
75
|
export {};
|
|
74
|
-
//# sourceMappingURL=
|
|
76
|
+
//# sourceMappingURL=FlowmapLayer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FlowmapLayer.d.ts","sourceRoot":"","sources":["../src/FlowmapLayer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,323 @@
|
|
|
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
|
+
/*
|
|
11
|
+
* Copyright 2022 FlowmapBlue
|
|
12
|
+
*
|
|
13
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
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
|
+
*
|
|
25
|
+
*/
|
|
26
|
+
import { CompositeLayer } from '@deck.gl/core';
|
|
27
|
+
import { ScatterplotLayer } from '@deck.gl/layers';
|
|
28
|
+
import { colorAsRgba, getFlowLineAttributesByIndex, getFlowmapColors, getOuterCircleRadiusByIndex, getLocationCentroidByIndex, isFlowmapData, isFlowmapDataProvider, LocalFlowmapDataProvider, LocationFilterMode, FlowmapAggregateAccessors, } from '@flowmap.gl/data';
|
|
29
|
+
import AnimatedFlowLinesLayer from './AnimatedFlowLinesLayer';
|
|
30
|
+
import FlowCirclesLayer from './FlowCirclesLayer';
|
|
31
|
+
import FlowLinesLayer from './FlowLinesLayer';
|
|
32
|
+
import { PickingType, } from './types';
|
|
33
|
+
var HighlightType;
|
|
34
|
+
(function (HighlightType) {
|
|
35
|
+
HighlightType["LOCATION"] = "location";
|
|
36
|
+
HighlightType["FLOW"] = "flow";
|
|
37
|
+
})(HighlightType || (HighlightType = {}));
|
|
38
|
+
export default class FlowmapLayer extends CompositeLayer {
|
|
39
|
+
constructor(props) {
|
|
40
|
+
super(Object.assign(Object.assign({}, props), { onHover: (info, event) => {
|
|
41
|
+
// TODO: if (lastHoverEventStartTimeRef > startTime) {
|
|
42
|
+
// // Skipping, because this is not the latest hover event
|
|
43
|
+
// return;
|
|
44
|
+
// }
|
|
45
|
+
this.setState({ highlightedObject: this._getHighlightedObject(info) });
|
|
46
|
+
const { onHover } = props;
|
|
47
|
+
if (onHover) {
|
|
48
|
+
this._getFlowmapLayerPickingInfo(info).then((info) => onHover(info, event));
|
|
49
|
+
}
|
|
50
|
+
}, onClick: (info, event) => {
|
|
51
|
+
const { onClick } = props;
|
|
52
|
+
if (onClick) {
|
|
53
|
+
this._getFlowmapLayerPickingInfo(info).then((info) => {
|
|
54
|
+
if (info) {
|
|
55
|
+
onClick(info, event);
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
} }));
|
|
60
|
+
}
|
|
61
|
+
initializeState() {
|
|
62
|
+
this.state = {
|
|
63
|
+
accessors: new FlowmapAggregateAccessors(this.props),
|
|
64
|
+
dataProvider: this._makeDataProvider(),
|
|
65
|
+
layersData: undefined,
|
|
66
|
+
highlightedObject: undefined,
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
_updateAccessors() {
|
|
70
|
+
var _a, _b;
|
|
71
|
+
(_b = (_a = this.state) === null || _a === void 0 ? void 0 : _a.dataProvider) === null || _b === void 0 ? void 0 : _b.setAccessors(this.props);
|
|
72
|
+
this.setState({ accessors: new FlowmapAggregateAccessors(this.props) });
|
|
73
|
+
}
|
|
74
|
+
_makeDataProvider() {
|
|
75
|
+
const { data } = this.props;
|
|
76
|
+
if (isFlowmapDataProvider(data)) {
|
|
77
|
+
return data;
|
|
78
|
+
}
|
|
79
|
+
else if (isFlowmapData(data)) {
|
|
80
|
+
const dataProvider = new LocalFlowmapDataProvider(this.props);
|
|
81
|
+
dataProvider.setFlowmapData(data);
|
|
82
|
+
return dataProvider;
|
|
83
|
+
}
|
|
84
|
+
throw new Error('FlowmapLayer: data must be a FlowmapDataProvider or FlowmapData');
|
|
85
|
+
}
|
|
86
|
+
_updateDataProvider() {
|
|
87
|
+
this.setState({ dataProvider: this._makeDataProvider() });
|
|
88
|
+
}
|
|
89
|
+
shouldUpdateState(params) {
|
|
90
|
+
const { changeFlags } = params;
|
|
91
|
+
// if (this._viewportChanged()) {
|
|
92
|
+
// return true;
|
|
93
|
+
// }
|
|
94
|
+
if (changeFlags.viewportChanged) {
|
|
95
|
+
return true;
|
|
96
|
+
}
|
|
97
|
+
return super.shouldUpdateState(params);
|
|
98
|
+
// TODO: be smarter on when to update
|
|
99
|
+
// (e.g. ignore viewport changes when adaptiveScalesEnabled and clustering are false)
|
|
100
|
+
}
|
|
101
|
+
updateState({ oldProps, props, changeFlags }) {
|
|
102
|
+
const { dataProvider, highlightedObject } = this.state || {};
|
|
103
|
+
if (!dataProvider) {
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
106
|
+
if (changeFlags.propsChanged) {
|
|
107
|
+
this._updateAccessors();
|
|
108
|
+
}
|
|
109
|
+
if (changeFlags.dataChanged) {
|
|
110
|
+
this._updateDataProvider();
|
|
111
|
+
}
|
|
112
|
+
if (changeFlags.viewportChanged || changeFlags.dataChanged) {
|
|
113
|
+
this.setState({
|
|
114
|
+
highlightedObject: undefined,
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
if (changeFlags.viewportChanged || changeFlags.propsOrDataChanged) {
|
|
118
|
+
dataProvider.setFlowmapState(this._getFlowmapState());
|
|
119
|
+
(() => __awaiter(this, void 0, void 0, function* () {
|
|
120
|
+
const layersData = yield dataProvider.getLayersData();
|
|
121
|
+
this.setState({ layersData });
|
|
122
|
+
}))();
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
_getSettingsState() {
|
|
126
|
+
const { locationTotalsEnabled, adaptiveScalesEnabled, animationEnabled, clusteringEnabled, clusteringLevel, fadeEnabled, fadeOpacityEnabled, clusteringAuto, darkMode, fadeAmount, colorScheme, highlightColor, maxTopFlowsDisplayNum, } = this.props;
|
|
127
|
+
return {
|
|
128
|
+
locationTotalsEnabled,
|
|
129
|
+
adaptiveScalesEnabled,
|
|
130
|
+
animationEnabled,
|
|
131
|
+
clusteringEnabled,
|
|
132
|
+
clusteringLevel,
|
|
133
|
+
fadeEnabled,
|
|
134
|
+
fadeOpacityEnabled,
|
|
135
|
+
clusteringAuto,
|
|
136
|
+
darkMode,
|
|
137
|
+
fadeAmount,
|
|
138
|
+
colorScheme,
|
|
139
|
+
highlightColor,
|
|
140
|
+
maxTopFlowsDisplayNum,
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
_getFlowmapState() {
|
|
144
|
+
return {
|
|
145
|
+
viewport: asViewState(this.context.viewport),
|
|
146
|
+
filterState: {
|
|
147
|
+
selectedLocations: undefined,
|
|
148
|
+
locationFilterMode: LocationFilterMode.ALL,
|
|
149
|
+
selectedTimeRange: undefined,
|
|
150
|
+
},
|
|
151
|
+
settingsState: this._getSettingsState(),
|
|
152
|
+
};
|
|
153
|
+
}
|
|
154
|
+
_getFlowmapLayerPickingInfo(info) {
|
|
155
|
+
var _a;
|
|
156
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
157
|
+
const { index, sourceLayer } = info;
|
|
158
|
+
const { dataProvider, accessors } = this.state || {};
|
|
159
|
+
if (!dataProvider || !accessors) {
|
|
160
|
+
return undefined;
|
|
161
|
+
}
|
|
162
|
+
const commonInfo = {
|
|
163
|
+
// ...info,
|
|
164
|
+
layer: info.layer,
|
|
165
|
+
index: info.index,
|
|
166
|
+
x: info.x,
|
|
167
|
+
y: info.y,
|
|
168
|
+
coordinate: info.coordinate,
|
|
169
|
+
};
|
|
170
|
+
if (sourceLayer instanceof FlowLinesLayer ||
|
|
171
|
+
sourceLayer instanceof AnimatedFlowLinesLayer) {
|
|
172
|
+
const flow = index === -1 ? undefined : yield dataProvider.getFlowByIndex(index);
|
|
173
|
+
if (flow) {
|
|
174
|
+
const origin = yield dataProvider.getLocationById(accessors.getFlowOriginId(flow));
|
|
175
|
+
const dest = yield dataProvider.getLocationById(accessors.getFlowDestId(flow));
|
|
176
|
+
if (origin && dest) {
|
|
177
|
+
return Object.assign(Object.assign({}, commonInfo), { type: PickingType.FLOW, object: flow, origin: origin, dest: dest, count: accessors.getFlowMagnitude(flow) });
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
else if (sourceLayer instanceof FlowCirclesLayer) {
|
|
182
|
+
const location = index === -1 ? undefined : yield dataProvider.getLocationByIndex(index);
|
|
183
|
+
if (location) {
|
|
184
|
+
const id = accessors.getLocationId(location);
|
|
185
|
+
const name = accessors.getLocationName(location);
|
|
186
|
+
const totals = yield dataProvider.getTotalsForLocation(id);
|
|
187
|
+
const { circleAttributes } = ((_a = this.state) === null || _a === void 0 ? void 0 : _a.layersData) || {};
|
|
188
|
+
if (totals && circleAttributes) {
|
|
189
|
+
const circleRadius = getOuterCircleRadiusByIndex(circleAttributes, info.index);
|
|
190
|
+
return Object.assign(Object.assign({}, commonInfo), { type: PickingType.LOCATION, object: location, id,
|
|
191
|
+
name,
|
|
192
|
+
totals, circleRadius: circleRadius, event: undefined });
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
return undefined;
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
_getHighlightedObject(info) {
|
|
200
|
+
var _a, _b;
|
|
201
|
+
const { index, sourceLayer } = info;
|
|
202
|
+
if (index < 0)
|
|
203
|
+
return undefined;
|
|
204
|
+
if (sourceLayer instanceof FlowLinesLayer ||
|
|
205
|
+
sourceLayer instanceof AnimatedFlowLinesLayer) {
|
|
206
|
+
const { lineAttributes } = ((_a = this.state) === null || _a === void 0 ? void 0 : _a.layersData) || {};
|
|
207
|
+
if (lineAttributes) {
|
|
208
|
+
let attrs = getFlowLineAttributesByIndex(lineAttributes, index);
|
|
209
|
+
if (this.props.fadeOpacityEnabled) {
|
|
210
|
+
attrs = Object.assign(Object.assign({}, attrs), { attributes: Object.assign(Object.assign({}, attrs.attributes), { getColor: Object.assign(Object.assign({}, attrs.attributes.getColor), { value: new Uint8Array([
|
|
211
|
+
...attrs.attributes.getColor.value.slice(0, 3),
|
|
212
|
+
255, // the highlight color should be always opaque
|
|
213
|
+
]) }) }) });
|
|
214
|
+
}
|
|
215
|
+
return {
|
|
216
|
+
type: HighlightType.FLOW,
|
|
217
|
+
lineAttributes: attrs,
|
|
218
|
+
};
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
else if (sourceLayer instanceof FlowCirclesLayer) {
|
|
222
|
+
const { circleAttributes } = ((_b = this.state) === null || _b === void 0 ? void 0 : _b.layersData) || {};
|
|
223
|
+
if (circleAttributes) {
|
|
224
|
+
return {
|
|
225
|
+
type: HighlightType.LOCATION,
|
|
226
|
+
centroid: getLocationCentroidByIndex(circleAttributes, index),
|
|
227
|
+
radius: getOuterCircleRadiusByIndex(circleAttributes, index),
|
|
228
|
+
};
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
return undefined;
|
|
232
|
+
}
|
|
233
|
+
renderLayers() {
|
|
234
|
+
var _a;
|
|
235
|
+
const layers = [];
|
|
236
|
+
if ((_a = this.state) === null || _a === void 0 ? void 0 : _a.layersData) {
|
|
237
|
+
const { layersData, highlightedObject } = this.state;
|
|
238
|
+
const { circleAttributes, lineAttributes } = layersData || {};
|
|
239
|
+
if (circleAttributes && lineAttributes) {
|
|
240
|
+
const flowmapColors = getFlowmapColors(this._getSettingsState());
|
|
241
|
+
const outlineColor = colorAsRgba(flowmapColors.outlineColor || (this.props.darkMode ? '#000' : '#fff'));
|
|
242
|
+
const commonLineLayerProps = {
|
|
243
|
+
data: lineAttributes,
|
|
244
|
+
parameters: Object.assign(Object.assign({}, this.props.parameters), {
|
|
245
|
+
// prevent z-fighting at non-zero bearing/pitch
|
|
246
|
+
depthTest: false }),
|
|
247
|
+
};
|
|
248
|
+
if (this.props.animationEnabled) {
|
|
249
|
+
layers.push(
|
|
250
|
+
// @ts-ignore
|
|
251
|
+
new AnimatedFlowLinesLayer(Object.assign({}, this.getSubLayerProps(Object.assign(Object.assign({}, commonLineLayerProps), { id: 'animated-flow-lines', drawOutline: false, thicknessUnit: 20 })))));
|
|
252
|
+
}
|
|
253
|
+
else {
|
|
254
|
+
layers.push(new FlowLinesLayer(Object.assign({}, this.getSubLayerProps(Object.assign(Object.assign({}, commonLineLayerProps), { id: 'flow-lines', drawOutline: true, outlineColor: outlineColor })))));
|
|
255
|
+
}
|
|
256
|
+
layers.push(new FlowCirclesLayer(this.getSubLayerProps({
|
|
257
|
+
id: 'circles',
|
|
258
|
+
data: circleAttributes,
|
|
259
|
+
emptyColor: [0, 0, 0, 255],
|
|
260
|
+
emptyOutlineColor: [0, 0, 0, 255],
|
|
261
|
+
})));
|
|
262
|
+
if (highlightedObject) {
|
|
263
|
+
switch (highlightedObject.type) {
|
|
264
|
+
case HighlightType.LOCATION:
|
|
265
|
+
layers.push(new ScatterplotLayer(Object.assign({}, this.getSubLayerProps({
|
|
266
|
+
id: 'location-highlight',
|
|
267
|
+
data: [highlightedObject],
|
|
268
|
+
pickable: false,
|
|
269
|
+
stroked: true,
|
|
270
|
+
filled: false,
|
|
271
|
+
lineWidthUnits: 'pixels',
|
|
272
|
+
getLineWidth: 2,
|
|
273
|
+
radiusUnits: 'pixels',
|
|
274
|
+
getRadius: (d) => d.radius,
|
|
275
|
+
getLineColor: colorAsRgba(this.props.highlightColor),
|
|
276
|
+
getPosition: (d) => d.centroid,
|
|
277
|
+
}))));
|
|
278
|
+
break;
|
|
279
|
+
case HighlightType.FLOW:
|
|
280
|
+
layers.push(new FlowLinesLayer(Object.assign({}, this.getSubLayerProps({
|
|
281
|
+
id: 'flow-highlight',
|
|
282
|
+
data: highlightedObject.lineAttributes,
|
|
283
|
+
drawOutline: true,
|
|
284
|
+
pickable: false,
|
|
285
|
+
outlineColor: colorAsRgba(this.props.highlightColor),
|
|
286
|
+
outlineThickness: 1,
|
|
287
|
+
}))));
|
|
288
|
+
break;
|
|
289
|
+
}
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
return layers;
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
FlowmapLayer.defaultProps = {
|
|
297
|
+
darkMode: true,
|
|
298
|
+
fadeAmount: 50,
|
|
299
|
+
locationTotalsEnabled: true,
|
|
300
|
+
animationEnabled: false,
|
|
301
|
+
clusteringEnabled: true,
|
|
302
|
+
fadeEnabled: true,
|
|
303
|
+
fadeOpacityEnabled: false,
|
|
304
|
+
clusteringAuto: true,
|
|
305
|
+
clusteringLevel: undefined,
|
|
306
|
+
adaptiveScalesEnabled: true,
|
|
307
|
+
colorScheme: 'Teal',
|
|
308
|
+
highlightColor: 'orange',
|
|
309
|
+
maxTopFlowsDisplayNum: 5000,
|
|
310
|
+
};
|
|
311
|
+
function asViewState(viewport) {
|
|
312
|
+
const { width, height, longitude, latitude, zoom, pitch, bearing } = viewport;
|
|
313
|
+
return {
|
|
314
|
+
width,
|
|
315
|
+
height,
|
|
316
|
+
longitude,
|
|
317
|
+
latitude,
|
|
318
|
+
zoom,
|
|
319
|
+
pitch,
|
|
320
|
+
bearing,
|
|
321
|
+
};
|
|
322
|
+
}
|
|
323
|
+
//# 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} from '@deck.gl/layers';\nimport {\n  colorAsRgba,\n  FlowLinesLayerAttributes,\n  FlowmapData,\n  FlowmapDataAccessors,\n  FlowmapDataProvider,\n  getFlowLineAttributesByIndex,\n  getFlowmapColors,\n  getOuterCircleRadiusByIndex,\n  getLocationCentroidByIndex,\n  isFlowmapData,\n  isFlowmapDataProvider,\n  LayersData,\n  LocalFlowmapDataProvider,\n  LocationFilterMode,\n  ViewportProps,\n  FlowmapAggregateAccessors,\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> | FlowmapDataProvider<L, F>;\n  locationTotalsEnabled?: 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;\n  highlightColor?: string;\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\nenum HighlightType {\n  LOCATION = 'location',\n  FLOW = 'flow',\n}\n\ntype HighlightedLocationObject = {\n  type: HighlightType.LOCATION;\n  centroid: [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};\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    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        // TODO: if (lastHoverEventStartTimeRef > startTime) {\n        //   // Skipping, because this is not the latest hover event\n        //   return;\n        // }\n        this.setState({highlightedObject: this._getHighlightedObject(info)});\n        const {onHover} = props;\n        if (onHover) {\n          this._getFlowmapLayerPickingInfo(info).then((info) =>\n            onHover(info, event),\n          );\n        }\n      },\n      onClick: (info: PickingInfo<any>, event: SourceEvent) => {\n        const {onClick} = props;\n        if (onClick) {\n          this._getFlowmapLayerPickingInfo(info).then((info) => {\n            if (info) {\n              onClick(info, event);\n            }\n          });\n        }\n      },\n    });\n  }\n\n  initializeState() {\n    this.state = {\n      accessors: new FlowmapAggregateAccessors<L, F>(this.props),\n      dataProvider: this._makeDataProvider(),\n      layersData: undefined,\n      highlightedObject: undefined,\n    };\n  }\n\n  private _updateAccessors() {\n    this.state?.dataProvider?.setAccessors(this.props);\n    this.setState({accessors: new FlowmapAggregateAccessors(this.props)});\n  }\n\n  private _makeDataProvider() {\n    const {data} = this.props;\n    if (isFlowmapDataProvider<L, F>(data)) {\n      return data;\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._makeDataProvider()});\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    const {dataProvider, highlightedObject} = this.state || {};\n    if (!dataProvider) {\n      return;\n    }\n\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({\n        highlightedObject: undefined,\n      });\n    }\n\n    if (changeFlags.viewportChanged || changeFlags.propsOrDataChanged) {\n      dataProvider.setFlowmapState(this._getFlowmapState());\n      (async () => {\n        const layersData = await dataProvider.getLayersData();\n        this.setState({layersData});\n      })();\n    }\n  }\n\n  private _getSettingsState() {\n    const {\n      locationTotalsEnabled,\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      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: asViewState(this.context.viewport),\n      filterState: {\n        selectedLocations: undefined,\n        locationFilterMode: LocationFilterMode.ALL,\n        selectedTimeRange: undefined,\n      },\n      settingsState: 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      layer: info.layer,\n      index: info.index,\n      x: info.x,\n      y: info.y,\n      coordinate: info.coordinate,\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            type: PickingType.FLOW,\n            object: flow,\n            origin: origin,\n            dest: dest,\n            count: accessors.getFlowMagnitude(flow),\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            type: PickingType.LOCATION,\n            object: location,\n            id,\n            name,\n            totals,\n            circleRadius: circleRadius,\n            event: undefined,\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          centroid: getLocationCentroidByIndex(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} = 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: [0, 0, 0, 255],\n              emptyOutlineColor: [0, 0, 0, 255],\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                    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.centroid,\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                  }),\n                }),\n              );\n              break;\n          }\n        }\n      }\n    }\n\n    return layers;\n  }\n}\n\nfunction asViewState(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
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export { default as AnimatedFlowLinesLayer } from './AnimatedFlowLinesLayer';
|
|
2
2
|
export { default as FlowLinesLayer } from './FlowLinesLayer';
|
|
3
3
|
export { default as FlowCirclesLayer } from './FlowCirclesLayer';
|
|
4
|
-
export { default as
|
|
5
|
-
export type {
|
|
4
|
+
export { default as FlowmapLayer } from './FlowmapLayer';
|
|
5
|
+
export type { FlowmapLayerProps } from './FlowmapLayer';
|
|
6
6
|
export * from './types';
|
|
7
7
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export { default as AnimatedFlowLinesLayer } from './AnimatedFlowLinesLayer';
|
|
2
2
|
export { default as FlowLinesLayer } from './FlowLinesLayer';
|
|
3
3
|
export { default as FlowCirclesLayer } from './FlowCirclesLayer';
|
|
4
|
-
export { default as
|
|
4
|
+
export { default as FlowmapLayer } from './FlowmapLayer';
|
|
5
5
|
export * from './types';
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE9BQU8sSUFBSSxzQkFBc0IsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQzNFLE9BQU8sRUFBQyxPQUFPLElBQUksY0FBYyxFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDM0QsT0FBTyxFQUFDLE9BQU8sSUFBSSxnQkFBZ0IsRUFBQyxNQUFNLG9CQUFvQixDQUFDO0FBQy9ELE9BQU8sRUFBQyxPQUFPLElBQUksWUFBWSxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFHdkQsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQge2RlZmF1bHQgYXMgQW5pbWF0ZWRGbG93TGluZXNMYXllcn0gZnJvbSAnLi9BbmltYXRlZEZsb3dMaW5lc0xheWVyJztcbmV4cG9ydCB7ZGVmYXVsdCBhcyBGbG93TGluZXNMYXllcn0gZnJvbSAnLi9GbG93TGluZXNMYXllcic7XG5leHBvcnQge2RlZmF1bHQgYXMgRmxvd0NpcmNsZXNMYXllcn0gZnJvbSAnLi9GbG93Q2lyY2xlc0xheWVyJztcbmV4cG9ydCB7ZGVmYXVsdCBhcyBGbG93bWFwTGF5ZXJ9IGZyb20gJy4vRmxvd21hcExheWVyJztcbmV4cG9ydCB0eXBlIHtGbG93bWFwTGF5ZXJQcm9wc30gZnJvbSAnLi9GbG93bWFwTGF5ZXInO1xuXG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbiJdfQ==
|
package/dist/types.d.ts
CHANGED
|
@@ -27,5 +27,5 @@ export interface FlowPickingInfo<L, F> extends PickingInfo<F | AggregateFlow> {
|
|
|
27
27
|
dest: L | ClusterNode;
|
|
28
28
|
count: number;
|
|
29
29
|
}
|
|
30
|
-
export declare type
|
|
30
|
+
export declare type FlowmapLayerPickingInfo<L, F> = LocationPickingInfo<L> | FlowPickingInfo<L, F>;
|
|
31
31
|
//# sourceMappingURL=types.d.ts.map
|
package/dist/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EAEb,WAAW,EACX,cAAc,EACf,MAAM,kBAAkB,CAAC;AAE1B,oBAAY,UAAU,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAEjD,oBAAY,WAAW;IACrB,QAAQ,aAAa;IACrB,IAAI,SAAS;CAEd;AAED,oBAAY,WAAW,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;AAE9C,MAAM,WAAW,WAAW,CAAC,CAAC;IAC5B,KAAK,EAAE,WAAW,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,CAAC,GAAG,SAAS,CAAC;IACtB,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,UAAU,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAC9B;AAED,MAAM,WAAW,mBAAmB,CAAC,CAAC,CAAE,SAAQ,WAAW,CAAC,CAAC,GAAG,WAAW,CAAC;IAC1E,IAAI,EAAE,WAAW,CAAC,QAAQ,CAAC;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,cAAc,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,KAAK,EAAE,UAAU,GAAG,SAAS,CAAC;CAC/B;AAED,MAAM,WAAW,eAAe,CAAC,CAAC,EAAE,CAAC,CAAE,SAAQ,WAAW,CAAC,CAAC,GAAG,aAAa,CAAC;IAC3E,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC;IACvB,MAAM,EAAE,CAAC,GAAG,WAAW,CAAC;IACxB,IAAI,EAAE,CAAC,GAAG,WAAW,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;CACf;AAOD,oBAAY,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EAEb,WAAW,EACX,cAAc,EACf,MAAM,kBAAkB,CAAC;AAE1B,oBAAY,UAAU,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAEjD,oBAAY,WAAW;IACrB,QAAQ,aAAa;IACrB,IAAI,SAAS;CAEd;AAED,oBAAY,WAAW,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;AAE9C,MAAM,WAAW,WAAW,CAAC,CAAC;IAC5B,KAAK,EAAE,WAAW,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,CAAC,GAAG,SAAS,CAAC;IACtB,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,UAAU,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAC9B;AAED,MAAM,WAAW,mBAAmB,CAAC,CAAC,CAAE,SAAQ,WAAW,CAAC,CAAC,GAAG,WAAW,CAAC;IAC1E,IAAI,EAAE,WAAW,CAAC,QAAQ,CAAC;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,cAAc,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,KAAK,EAAE,UAAU,GAAG,SAAS,CAAC;CAC/B;AAED,MAAM,WAAW,eAAe,CAAC,CAAC,EAAE,CAAC,CAAE,SAAQ,WAAW,CAAC,CAAC,GAAG,aAAa,CAAC;IAC3E,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC;IACvB,MAAM,EAAE,CAAC,GAAG,WAAW,CAAC;IACxB,IAAI,EAAE,CAAC,GAAG,WAAW,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;CACf;AAOD,oBAAY,uBAAuB,CAAC,CAAC,EAAE,CAAC,IACpC,mBAAmB,CAAC,CAAC,CAAC,GAEtB,eAAe,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC"}
|
package/dist/types.js
CHANGED
|
@@ -17,4 +17,4 @@ export var PickingType;
|
|
|
17
17
|
// .type === 'FeatureCollection'
|
|
18
18
|
// );
|
|
19
19
|
// }
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBU0EsTUFBTSxDQUFOLElBQVksV0FJWDtBQUpELFdBQVksV0FBVztJQUNyQixvQ0FBcUIsQ0FBQTtJQUNyQiw0QkFBYSxDQUFBO0lBQ2IsbUNBQW1DO0FBQ3JDLENBQUMsRUFKVyxXQUFXLEtBQVgsV0FBVyxRQUl0QjtBQXVDRCw2REFBNkQ7QUFDN0QsNERBQTREO0FBRTVELDBCQUEwQjtBQUMxQiw0REFBNEQ7QUFDNUQsc0JBQXNCO0FBRXRCLHVDQUF1QztBQUN2QywwQkFBMEI7QUFDMUIsMEVBQTBFO0FBQzFFLGFBQWE7QUFDYiwyRUFBMkU7QUFDM0Usc0NBQXNDO0FBQ3RDLE9BQU87QUFDUCxJQUFJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQWdncmVnYXRlRmxvdyxcbiAgQ2x1c3RlcixcbiAgQ2x1c3Rlck5vZGUsXG4gIExvY2F0aW9uVG90YWxzLFxufSBmcm9tICdAZmxvd21hcC5nbC9kYXRhJztcblxuZXhwb3J0IHR5cGUgTGF5ZXJQcm9wcyA9IFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xuXG5leHBvcnQgZW51bSBQaWNraW5nVHlwZSB7XG4gIExPQ0FUSU9OID0gJ2xvY2F0aW9uJyxcbiAgRkxPVyA9ICdmbG93JyxcbiAgLy8gTE9DQVRJT05fQVJFQSA9ICdsb2NhdGlvbi1hcmVhJyxcbn1cblxuZXhwb3J0IHR5cGUgRGVja0dMTGF5ZXIgPSBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xuXG5leHBvcnQgaW50ZXJmYWNlIFBpY2tpbmdJbmZvPFQ+IHtcbiAgbGF5ZXI6IERlY2tHTExheWVyO1xuICBpbmRleDogbnVtYmVyO1xuICBvYmplY3Q6IFQgfCB1bmRlZmluZWQ7XG4gIHg6IG51bWJlcjtcbiAgeTogbnVtYmVyO1xuICBjb29yZGluYXRlOiBbbnVtYmVyLCBudW1iZXJdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExvY2F0aW9uUGlja2luZ0luZm88TD4gZXh0ZW5kcyBQaWNraW5nSW5mbzxMIHwgQ2x1c3Rlck5vZGU+IHtcbiAgdHlwZTogUGlja2luZ1R5cGUuTE9DQVRJT047XG4gIGlkOiBzdHJpbmc7XG4gIG5hbWU6IHN0cmluZztcbiAgdG90YWxzOiBMb2NhdGlvblRvdGFscztcbiAgY2lyY2xlUmFkaXVzOiBudW1iZXI7XG4gIGV2ZW50OiBNb3VzZUV2ZW50IHwgdW5kZWZpbmVkO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZsb3dQaWNraW5nSW5mbzxMLCBGPiBleHRlbmRzIFBpY2tpbmdJbmZvPEYgfCBBZ2dyZWdhdGVGbG93PiB7XG4gIHR5cGU6IFBpY2tpbmdUeXBlLkZMT1c7XG4gIG9yaWdpbjogTCB8IENsdXN0ZXJOb2RlO1xuICBkZXN0OiBMIHwgQ2x1c3Rlck5vZGU7XG4gIGNvdW50OiBudW1iZXI7XG59XG5cbi8vIGV4cG9ydCBpbnRlcmZhY2UgTG9jYXRpb25BcmVhUGlja2luZ0luZm8gZXh0ZW5kcyBQaWNraW5nSW5mbzxQaWNraW5nSW5mb0RhdGE+
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBU0EsTUFBTSxDQUFOLElBQVksV0FJWDtBQUpELFdBQVksV0FBVztJQUNyQixvQ0FBcUIsQ0FBQTtJQUNyQiw0QkFBYSxDQUFBO0lBQ2IsbUNBQW1DO0FBQ3JDLENBQUMsRUFKVyxXQUFXLEtBQVgsV0FBVyxRQUl0QjtBQXVDRCw2REFBNkQ7QUFDN0QsNERBQTREO0FBRTVELDBCQUEwQjtBQUMxQiw0REFBNEQ7QUFDNUQsc0JBQXNCO0FBRXRCLHVDQUF1QztBQUN2QywwQkFBMEI7QUFDMUIsMEVBQTBFO0FBQzFFLGFBQWE7QUFDYiwyRUFBMkU7QUFDM0Usc0NBQXNDO0FBQ3RDLE9BQU87QUFDUCxJQUFJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQWdncmVnYXRlRmxvdyxcbiAgQ2x1c3RlcixcbiAgQ2x1c3Rlck5vZGUsXG4gIExvY2F0aW9uVG90YWxzLFxufSBmcm9tICdAZmxvd21hcC5nbC9kYXRhJztcblxuZXhwb3J0IHR5cGUgTGF5ZXJQcm9wcyA9IFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xuXG5leHBvcnQgZW51bSBQaWNraW5nVHlwZSB7XG4gIExPQ0FUSU9OID0gJ2xvY2F0aW9uJyxcbiAgRkxPVyA9ICdmbG93JyxcbiAgLy8gTE9DQVRJT05fQVJFQSA9ICdsb2NhdGlvbi1hcmVhJyxcbn1cblxuZXhwb3J0IHR5cGUgRGVja0dMTGF5ZXIgPSBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xuXG5leHBvcnQgaW50ZXJmYWNlIFBpY2tpbmdJbmZvPFQ+IHtcbiAgbGF5ZXI6IERlY2tHTExheWVyO1xuICBpbmRleDogbnVtYmVyO1xuICBvYmplY3Q6IFQgfCB1bmRlZmluZWQ7XG4gIHg6IG51bWJlcjtcbiAgeTogbnVtYmVyO1xuICBjb29yZGluYXRlOiBbbnVtYmVyLCBudW1iZXJdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExvY2F0aW9uUGlja2luZ0luZm88TD4gZXh0ZW5kcyBQaWNraW5nSW5mbzxMIHwgQ2x1c3Rlck5vZGU+IHtcbiAgdHlwZTogUGlja2luZ1R5cGUuTE9DQVRJT047XG4gIGlkOiBzdHJpbmc7XG4gIG5hbWU6IHN0cmluZztcbiAgdG90YWxzOiBMb2NhdGlvblRvdGFscztcbiAgY2lyY2xlUmFkaXVzOiBudW1iZXI7XG4gIGV2ZW50OiBNb3VzZUV2ZW50IHwgdW5kZWZpbmVkO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZsb3dQaWNraW5nSW5mbzxMLCBGPiBleHRlbmRzIFBpY2tpbmdJbmZvPEYgfCBBZ2dyZWdhdGVGbG93PiB7XG4gIHR5cGU6IFBpY2tpbmdUeXBlLkZMT1c7XG4gIG9yaWdpbjogTCB8IENsdXN0ZXJOb2RlO1xuICBkZXN0OiBMIHwgQ2x1c3Rlck5vZGU7XG4gIGNvdW50OiBudW1iZXI7XG59XG5cbi8vIGV4cG9ydCBpbnRlcmZhY2UgTG9jYXRpb25BcmVhUGlja2luZ0luZm8gZXh0ZW5kcyBQaWNraW5nSW5mbzxQaWNraW5nSW5mb0RhdGE+IHtcbi8vICAgdHlwZTogUGlja2luZ1R5cGUuTE9DQVRJT05fQVJFQTtcbi8vICAgb2JqZWN0OiBGbG93TG9jYXRpb247XG4vLyB9XG5cbmV4cG9ydCB0eXBlIEZsb3dtYXBMYXllclBpY2tpbmdJbmZvPEwsIEY+ID1cbiAgfCBMb2NhdGlvblBpY2tpbmdJbmZvPEw+XG4gIC8vIHwgTG9jYXRpb25BcmVhUGlja2luZ0luZm9cbiAgfCBGbG93UGlja2luZ0luZm88TCwgRj47XG5cbi8vIGltcG9ydCB7RmVhdHVyZUNvbGxlY3Rpb24sIEdlb21ldHJ5T2JqZWN0fSBmcm9tICdnZW9qc29uJztcbi8vIGV4cG9ydCB0eXBlIExvY2F0aW9uUHJvcGVydGllcyA9IFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xuXG4vLyBleHBvcnQgdHlwZSBMb2NhdGlvbnMgPVxuLy8gICB8IEZlYXR1cmVDb2xsZWN0aW9uPEdlb21ldHJ5T2JqZWN0LCBMb2NhdGlvblByb3BlcnRpZXM+XG4vLyAgIHwgRmxvd0xvY2F0aW9uW107XG5cbi8vIGV4cG9ydCBmdW5jdGlvbiBpc0ZlYXR1cmVDb2xsZWN0aW9uKFxuLy8gICBsb2NhdGlvbnM6IExvY2F0aW9ucyxcbi8vICk6IGxvY2F0aW9ucyBpcyBGZWF0dXJlQ29sbGVjdGlvbjxHZW9tZXRyeU9iamVjdCwgTG9jYXRpb25Qcm9wZXJ0aWVzPiB7XG4vLyAgIHJldHVybiAoXG4vLyAgICAgKGxvY2F0aW9ucyBhcyBGZWF0dXJlQ29sbGVjdGlvbjxHZW9tZXRyeU9iamVjdCwgTG9jYXRpb25Qcm9wZXJ0aWVzPilcbi8vICAgICAgIC50eXBlID09PSAnRmVhdHVyZUNvbGxlY3Rpb24nXG4vLyAgICk7XG4vLyB9XG4iXX0=
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@flowmap.gl/layers",
|
|
3
|
-
"version": "8.0.0-alpha.
|
|
3
|
+
"version": "8.0.0-alpha.5",
|
|
4
4
|
"main": "dist/index.js",
|
|
5
5
|
"module": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -18,7 +18,7 @@
|
|
|
18
18
|
"@luma.gl/constants": "^8.5.10",
|
|
19
19
|
"@luma.gl/core": "^8.5.10"
|
|
20
20
|
},
|
|
21
|
-
"gitHead": "
|
|
21
|
+
"gitHead": "301087551f76980d8d366ec6cdc39d8ad6fef2f2",
|
|
22
22
|
"publishConfig": {
|
|
23
23
|
"access": "public"
|
|
24
24
|
}
|
|
@@ -19,35 +19,33 @@ import {ScatterplotLayer} from '@deck.gl/layers';
|
|
|
19
19
|
import {
|
|
20
20
|
colorAsRgba,
|
|
21
21
|
FlowLinesLayerAttributes,
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
22
|
+
FlowmapData,
|
|
23
|
+
FlowmapDataAccessors,
|
|
24
|
+
FlowmapDataProvider,
|
|
25
25
|
getFlowLineAttributesByIndex,
|
|
26
|
-
|
|
26
|
+
getFlowmapColors,
|
|
27
27
|
getOuterCircleRadiusByIndex,
|
|
28
28
|
getLocationCentroidByIndex,
|
|
29
|
-
|
|
30
|
-
|
|
29
|
+
isFlowmapData,
|
|
30
|
+
isFlowmapDataProvider,
|
|
31
31
|
LayersData,
|
|
32
|
-
|
|
32
|
+
LocalFlowmapDataProvider,
|
|
33
33
|
LocationFilterMode,
|
|
34
34
|
ViewportProps,
|
|
35
|
-
|
|
36
|
-
ClusterNode,
|
|
37
|
-
AggregateFlow,
|
|
35
|
+
FlowmapAggregateAccessors,
|
|
38
36
|
} from '@flowmap.gl/data';
|
|
39
37
|
import AnimatedFlowLinesLayer from './AnimatedFlowLinesLayer';
|
|
40
38
|
import FlowCirclesLayer from './FlowCirclesLayer';
|
|
41
39
|
import FlowLinesLayer from './FlowLinesLayer';
|
|
42
40
|
import {
|
|
43
|
-
|
|
41
|
+
FlowmapLayerPickingInfo,
|
|
44
42
|
LayerProps,
|
|
45
43
|
PickingInfo,
|
|
46
44
|
PickingType,
|
|
47
45
|
} from './types';
|
|
48
46
|
|
|
49
|
-
export type
|
|
50
|
-
data:
|
|
47
|
+
export type FlowmapLayerProps<L, F> = {
|
|
48
|
+
data: FlowmapData<L, F> | FlowmapDataProvider<L, F>;
|
|
51
49
|
locationTotalsEnabled?: boolean;
|
|
52
50
|
adaptiveScalesEnabled?: boolean;
|
|
53
51
|
animationEnabled?: boolean;
|
|
@@ -60,12 +58,13 @@ export type FlowMapLayerProps<L, F> = {
|
|
|
60
58
|
fadeAmount?: number;
|
|
61
59
|
colorScheme?: string;
|
|
62
60
|
highlightColor?: string;
|
|
61
|
+
maxTopFlowsDisplayNum?: number;
|
|
63
62
|
onHover?: (
|
|
64
|
-
info:
|
|
63
|
+
info: FlowmapLayerPickingInfo<L, F> | undefined,
|
|
65
64
|
event: SourceEvent,
|
|
66
65
|
) => void;
|
|
67
|
-
onClick?: (info:
|
|
68
|
-
} & Partial<
|
|
66
|
+
onClick?: (info: FlowmapLayerPickingInfo<L, F>, event: SourceEvent) => void;
|
|
67
|
+
} & Partial<FlowmapDataAccessors<L, F>> &
|
|
69
68
|
LayerProps;
|
|
70
69
|
|
|
71
70
|
enum HighlightType {
|
|
@@ -87,15 +86,15 @@ type HighlightedFlowObject = {
|
|
|
87
86
|
type HighlightedObject = HighlightedLocationObject | HighlightedFlowObject;
|
|
88
87
|
|
|
89
88
|
type State<L, F> = {
|
|
90
|
-
accessors:
|
|
91
|
-
dataProvider:
|
|
89
|
+
accessors: FlowmapAggregateAccessors<L, F>;
|
|
90
|
+
dataProvider: FlowmapDataProvider<L, F>;
|
|
92
91
|
layersData: LayersData | undefined;
|
|
93
92
|
highlightedObject: HighlightedObject | undefined;
|
|
94
93
|
};
|
|
95
94
|
|
|
96
95
|
export type SourceEvent = {srcEvent: MouseEvent};
|
|
97
96
|
|
|
98
|
-
export default class
|
|
97
|
+
export default class FlowmapLayer<L, F> extends CompositeLayer {
|
|
99
98
|
static defaultProps = {
|
|
100
99
|
darkMode: true,
|
|
101
100
|
fadeAmount: 50,
|
|
@@ -109,10 +108,11 @@ export default class FlowMapLayer<L, F> extends CompositeLayer {
|
|
|
109
108
|
adaptiveScalesEnabled: true,
|
|
110
109
|
colorScheme: 'Teal',
|
|
111
110
|
highlightColor: 'orange',
|
|
111
|
+
maxTopFlowsDisplayNum: 5000,
|
|
112
112
|
};
|
|
113
113
|
state: State<L, F> | undefined;
|
|
114
114
|
|
|
115
|
-
public constructor(props:
|
|
115
|
+
public constructor(props: FlowmapLayerProps<L, F>) {
|
|
116
116
|
super({
|
|
117
117
|
...props,
|
|
118
118
|
onHover: (info: PickingInfo<any>, event: SourceEvent) => {
|
|
@@ -123,7 +123,7 @@ export default class FlowMapLayer<L, F> extends CompositeLayer {
|
|
|
123
123
|
this.setState({highlightedObject: this._getHighlightedObject(info)});
|
|
124
124
|
const {onHover} = props;
|
|
125
125
|
if (onHover) {
|
|
126
|
-
this.
|
|
126
|
+
this._getFlowmapLayerPickingInfo(info).then((info) =>
|
|
127
127
|
onHover(info, event),
|
|
128
128
|
);
|
|
129
129
|
}
|
|
@@ -131,7 +131,7 @@ export default class FlowMapLayer<L, F> extends CompositeLayer {
|
|
|
131
131
|
onClick: (info: PickingInfo<any>, event: SourceEvent) => {
|
|
132
132
|
const {onClick} = props;
|
|
133
133
|
if (onClick) {
|
|
134
|
-
this.
|
|
134
|
+
this._getFlowmapLayerPickingInfo(info).then((info) => {
|
|
135
135
|
if (info) {
|
|
136
136
|
onClick(info, event);
|
|
137
137
|
}
|
|
@@ -143,7 +143,7 @@ export default class FlowMapLayer<L, F> extends CompositeLayer {
|
|
|
143
143
|
|
|
144
144
|
initializeState() {
|
|
145
145
|
this.state = {
|
|
146
|
-
accessors: new
|
|
146
|
+
accessors: new FlowmapAggregateAccessors<L, F>(this.props),
|
|
147
147
|
dataProvider: this._makeDataProvider(),
|
|
148
148
|
layersData: undefined,
|
|
149
149
|
highlightedObject: undefined,
|
|
@@ -152,20 +152,20 @@ export default class FlowMapLayer<L, F> extends CompositeLayer {
|
|
|
152
152
|
|
|
153
153
|
private _updateAccessors() {
|
|
154
154
|
this.state?.dataProvider?.setAccessors(this.props);
|
|
155
|
-
this.setState({accessors: new
|
|
155
|
+
this.setState({accessors: new FlowmapAggregateAccessors(this.props)});
|
|
156
156
|
}
|
|
157
157
|
|
|
158
158
|
private _makeDataProvider() {
|
|
159
159
|
const {data} = this.props;
|
|
160
|
-
if (
|
|
160
|
+
if (isFlowmapDataProvider<L, F>(data)) {
|
|
161
161
|
return data;
|
|
162
|
-
} else if (
|
|
163
|
-
const dataProvider = new
|
|
164
|
-
dataProvider.
|
|
162
|
+
} else if (isFlowmapData<L, F>(data)) {
|
|
163
|
+
const dataProvider = new LocalFlowmapDataProvider<L, F>(this.props);
|
|
164
|
+
dataProvider.setFlowmapData(data);
|
|
165
165
|
return dataProvider;
|
|
166
166
|
}
|
|
167
167
|
throw new Error(
|
|
168
|
-
'
|
|
168
|
+
'FlowmapLayer: data must be a FlowmapDataProvider or FlowmapData',
|
|
169
169
|
);
|
|
170
170
|
}
|
|
171
171
|
|
|
@@ -205,7 +205,7 @@ export default class FlowMapLayer<L, F> extends CompositeLayer {
|
|
|
205
205
|
}
|
|
206
206
|
|
|
207
207
|
if (changeFlags.viewportChanged || changeFlags.propsOrDataChanged) {
|
|
208
|
-
dataProvider.
|
|
208
|
+
dataProvider.setFlowmapState(this._getFlowmapState());
|
|
209
209
|
(async () => {
|
|
210
210
|
const layersData = await dataProvider.getLayersData();
|
|
211
211
|
this.setState({layersData});
|
|
@@ -226,6 +226,8 @@ export default class FlowMapLayer<L, F> extends CompositeLayer {
|
|
|
226
226
|
darkMode,
|
|
227
227
|
fadeAmount,
|
|
228
228
|
colorScheme,
|
|
229
|
+
highlightColor,
|
|
230
|
+
maxTopFlowsDisplayNum,
|
|
229
231
|
} = this.props;
|
|
230
232
|
return {
|
|
231
233
|
locationTotalsEnabled,
|
|
@@ -239,10 +241,12 @@ export default class FlowMapLayer<L, F> extends CompositeLayer {
|
|
|
239
241
|
darkMode,
|
|
240
242
|
fadeAmount,
|
|
241
243
|
colorScheme,
|
|
244
|
+
highlightColor,
|
|
245
|
+
maxTopFlowsDisplayNum,
|
|
242
246
|
};
|
|
243
247
|
}
|
|
244
248
|
|
|
245
|
-
private
|
|
249
|
+
private _getFlowmapState() {
|
|
246
250
|
return {
|
|
247
251
|
viewport: asViewState(this.context.viewport),
|
|
248
252
|
filterState: {
|
|
@@ -254,9 +258,9 @@ export default class FlowMapLayer<L, F> extends CompositeLayer {
|
|
|
254
258
|
};
|
|
255
259
|
}
|
|
256
260
|
|
|
257
|
-
private async
|
|
261
|
+
private async _getFlowmapLayerPickingInfo(
|
|
258
262
|
info: Record<string, any>,
|
|
259
|
-
): Promise<
|
|
263
|
+
): Promise<FlowmapLayerPickingInfo<L, F> | undefined> {
|
|
260
264
|
const {index, sourceLayer} = info;
|
|
261
265
|
const {dataProvider, accessors} = this.state || {};
|
|
262
266
|
if (!dataProvider || !accessors) {
|
|
@@ -376,9 +380,9 @@ export default class FlowMapLayer<L, F> extends CompositeLayer {
|
|
|
376
380
|
const {layersData, highlightedObject} = this.state;
|
|
377
381
|
const {circleAttributes, lineAttributes} = layersData || {};
|
|
378
382
|
if (circleAttributes && lineAttributes) {
|
|
379
|
-
const
|
|
383
|
+
const flowmapColors = getFlowmapColors(this._getSettingsState());
|
|
380
384
|
const outlineColor = colorAsRgba(
|
|
381
|
-
|
|
385
|
+
flowmapColors.outlineColor || (this.props.darkMode ? '#000' : '#fff'),
|
|
382
386
|
);
|
|
383
387
|
const commonLineLayerProps = {
|
|
384
388
|
data: lineAttributes,
|
package/src/index.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export {default as AnimatedFlowLinesLayer} from './AnimatedFlowLinesLayer';
|
|
2
2
|
export {default as FlowLinesLayer} from './FlowLinesLayer';
|
|
3
3
|
export {default as FlowCirclesLayer} from './FlowCirclesLayer';
|
|
4
|
-
export {default as
|
|
5
|
-
export type {
|
|
4
|
+
export {default as FlowmapLayer} from './FlowmapLayer';
|
|
5
|
+
export type {FlowmapLayerProps} from './FlowmapLayer';
|
|
6
6
|
|
|
7
7
|
export * from './types';
|
package/src/types.ts
CHANGED
|
@@ -45,7 +45,7 @@ export interface FlowPickingInfo<L, F> extends PickingInfo<F | AggregateFlow> {
|
|
|
45
45
|
// object: FlowLocation;
|
|
46
46
|
// }
|
|
47
47
|
|
|
48
|
-
export type
|
|
48
|
+
export type FlowmapLayerPickingInfo<L, F> =
|
|
49
49
|
| LocationPickingInfo<L>
|
|
50
50
|
// | LocationAreaPickingInfo
|
|
51
51
|
| FlowPickingInfo<L, F>;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"FlowMapLayer.d.ts","sourceRoot":"","sources":["../src/FlowMapLayer.ts"],"names":[],"mappings":"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"}
|
package/dist/FlowMapLayer.js
DELETED
|
@@ -1,320 +0,0 @@
|
|
|
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
|
-
/*
|
|
11
|
-
* Copyright 2022 FlowmapBlue
|
|
12
|
-
*
|
|
13
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
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
|
-
*
|
|
25
|
-
*/
|
|
26
|
-
import { CompositeLayer } from '@deck.gl/core';
|
|
27
|
-
import { ScatterplotLayer } from '@deck.gl/layers';
|
|
28
|
-
import { colorAsRgba, getFlowLineAttributesByIndex, getFlowMapColors, getOuterCircleRadiusByIndex, getLocationCentroidByIndex, isFlowMapData, isFlowMapDataProvider, LocalFlowMapDataProvider, LocationFilterMode, FlowMapAggregateAccessors, } from '@flowmap.gl/data';
|
|
29
|
-
import AnimatedFlowLinesLayer from './AnimatedFlowLinesLayer';
|
|
30
|
-
import FlowCirclesLayer from './FlowCirclesLayer';
|
|
31
|
-
import FlowLinesLayer from './FlowLinesLayer';
|
|
32
|
-
import { PickingType, } from './types';
|
|
33
|
-
var HighlightType;
|
|
34
|
-
(function (HighlightType) {
|
|
35
|
-
HighlightType["LOCATION"] = "location";
|
|
36
|
-
HighlightType["FLOW"] = "flow";
|
|
37
|
-
})(HighlightType || (HighlightType = {}));
|
|
38
|
-
export default class FlowMapLayer extends CompositeLayer {
|
|
39
|
-
constructor(props) {
|
|
40
|
-
super(Object.assign(Object.assign({}, props), { onHover: (info, event) => {
|
|
41
|
-
// TODO: if (lastHoverEventStartTimeRef > startTime) {
|
|
42
|
-
// // Skipping, because this is not the latest hover event
|
|
43
|
-
// return;
|
|
44
|
-
// }
|
|
45
|
-
this.setState({ highlightedObject: this._getHighlightedObject(info) });
|
|
46
|
-
const { onHover } = props;
|
|
47
|
-
if (onHover) {
|
|
48
|
-
this._getFlowLayerPickingInfo(info).then((info) => onHover(info, event));
|
|
49
|
-
}
|
|
50
|
-
}, onClick: (info, event) => {
|
|
51
|
-
const { onClick } = props;
|
|
52
|
-
if (onClick) {
|
|
53
|
-
this._getFlowLayerPickingInfo(info).then((info) => {
|
|
54
|
-
if (info) {
|
|
55
|
-
onClick(info, event);
|
|
56
|
-
}
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
} }));
|
|
60
|
-
}
|
|
61
|
-
initializeState() {
|
|
62
|
-
this.state = {
|
|
63
|
-
accessors: new FlowMapAggregateAccessors(this.props),
|
|
64
|
-
dataProvider: this._makeDataProvider(),
|
|
65
|
-
layersData: undefined,
|
|
66
|
-
highlightedObject: undefined,
|
|
67
|
-
};
|
|
68
|
-
}
|
|
69
|
-
_updateAccessors() {
|
|
70
|
-
var _a, _b;
|
|
71
|
-
(_b = (_a = this.state) === null || _a === void 0 ? void 0 : _a.dataProvider) === null || _b === void 0 ? void 0 : _b.setAccessors(this.props);
|
|
72
|
-
this.setState({ accessors: new FlowMapAggregateAccessors(this.props) });
|
|
73
|
-
}
|
|
74
|
-
_makeDataProvider() {
|
|
75
|
-
const { data } = this.props;
|
|
76
|
-
if (isFlowMapDataProvider(data)) {
|
|
77
|
-
return data;
|
|
78
|
-
}
|
|
79
|
-
else if (isFlowMapData(data)) {
|
|
80
|
-
const dataProvider = new LocalFlowMapDataProvider(this.props);
|
|
81
|
-
dataProvider.setFlowMapData(data);
|
|
82
|
-
return dataProvider;
|
|
83
|
-
}
|
|
84
|
-
throw new Error('FlowMapLayer: data must be a FlowMapDataProvider or FlowMapData');
|
|
85
|
-
}
|
|
86
|
-
_updateDataProvider() {
|
|
87
|
-
this.setState({ dataProvider: this._makeDataProvider() });
|
|
88
|
-
}
|
|
89
|
-
shouldUpdateState(params) {
|
|
90
|
-
const { changeFlags } = params;
|
|
91
|
-
// if (this._viewportChanged()) {
|
|
92
|
-
// return true;
|
|
93
|
-
// }
|
|
94
|
-
if (changeFlags.viewportChanged) {
|
|
95
|
-
return true;
|
|
96
|
-
}
|
|
97
|
-
return super.shouldUpdateState(params);
|
|
98
|
-
// TODO: be smarter on when to update
|
|
99
|
-
// (e.g. ignore viewport changes when adaptiveScalesEnabled and clustering are false)
|
|
100
|
-
}
|
|
101
|
-
updateState({ oldProps, props, changeFlags }) {
|
|
102
|
-
const { dataProvider, highlightedObject } = this.state || {};
|
|
103
|
-
if (!dataProvider) {
|
|
104
|
-
return;
|
|
105
|
-
}
|
|
106
|
-
if (changeFlags.propsChanged) {
|
|
107
|
-
this._updateAccessors();
|
|
108
|
-
}
|
|
109
|
-
if (changeFlags.dataChanged) {
|
|
110
|
-
this._updateDataProvider();
|
|
111
|
-
}
|
|
112
|
-
if (changeFlags.viewportChanged || changeFlags.dataChanged) {
|
|
113
|
-
this.setState({
|
|
114
|
-
highlightedObject: undefined,
|
|
115
|
-
});
|
|
116
|
-
}
|
|
117
|
-
if (changeFlags.viewportChanged || changeFlags.propsOrDataChanged) {
|
|
118
|
-
dataProvider.setFlowMapState(this._getFlowMapState());
|
|
119
|
-
(() => __awaiter(this, void 0, void 0, function* () {
|
|
120
|
-
const layersData = yield dataProvider.getLayersData();
|
|
121
|
-
this.setState({ layersData });
|
|
122
|
-
}))();
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
_getSettingsState() {
|
|
126
|
-
const { locationTotalsEnabled, adaptiveScalesEnabled, animationEnabled, clusteringEnabled, clusteringLevel, fadeEnabled, fadeOpacityEnabled, clusteringAuto, darkMode, fadeAmount, colorScheme, } = this.props;
|
|
127
|
-
return {
|
|
128
|
-
locationTotalsEnabled,
|
|
129
|
-
adaptiveScalesEnabled,
|
|
130
|
-
animationEnabled,
|
|
131
|
-
clusteringEnabled,
|
|
132
|
-
clusteringLevel,
|
|
133
|
-
fadeEnabled,
|
|
134
|
-
fadeOpacityEnabled,
|
|
135
|
-
clusteringAuto,
|
|
136
|
-
darkMode,
|
|
137
|
-
fadeAmount,
|
|
138
|
-
colorScheme,
|
|
139
|
-
};
|
|
140
|
-
}
|
|
141
|
-
_getFlowMapState() {
|
|
142
|
-
return {
|
|
143
|
-
viewport: asViewState(this.context.viewport),
|
|
144
|
-
filterState: {
|
|
145
|
-
selectedLocations: undefined,
|
|
146
|
-
locationFilterMode: LocationFilterMode.ALL,
|
|
147
|
-
selectedTimeRange: undefined,
|
|
148
|
-
},
|
|
149
|
-
settingsState: this._getSettingsState(),
|
|
150
|
-
};
|
|
151
|
-
}
|
|
152
|
-
_getFlowLayerPickingInfo(info) {
|
|
153
|
-
var _a;
|
|
154
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
155
|
-
const { index, sourceLayer } = info;
|
|
156
|
-
const { dataProvider, accessors } = this.state || {};
|
|
157
|
-
if (!dataProvider || !accessors) {
|
|
158
|
-
return undefined;
|
|
159
|
-
}
|
|
160
|
-
const commonInfo = {
|
|
161
|
-
// ...info,
|
|
162
|
-
layer: info.layer,
|
|
163
|
-
index: info.index,
|
|
164
|
-
x: info.x,
|
|
165
|
-
y: info.y,
|
|
166
|
-
coordinate: info.coordinate,
|
|
167
|
-
};
|
|
168
|
-
if (sourceLayer instanceof FlowLinesLayer ||
|
|
169
|
-
sourceLayer instanceof AnimatedFlowLinesLayer) {
|
|
170
|
-
const flow = index === -1 ? undefined : yield dataProvider.getFlowByIndex(index);
|
|
171
|
-
if (flow) {
|
|
172
|
-
const origin = yield dataProvider.getLocationById(accessors.getFlowOriginId(flow));
|
|
173
|
-
const dest = yield dataProvider.getLocationById(accessors.getFlowDestId(flow));
|
|
174
|
-
if (origin && dest) {
|
|
175
|
-
return Object.assign(Object.assign({}, commonInfo), { type: PickingType.FLOW, object: flow, origin: origin, dest: dest, count: accessors.getFlowMagnitude(flow) });
|
|
176
|
-
}
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
else if (sourceLayer instanceof FlowCirclesLayer) {
|
|
180
|
-
const location = index === -1 ? undefined : yield dataProvider.getLocationByIndex(index);
|
|
181
|
-
if (location) {
|
|
182
|
-
const id = accessors.getLocationId(location);
|
|
183
|
-
const name = accessors.getLocationName(location);
|
|
184
|
-
const totals = yield dataProvider.getTotalsForLocation(id);
|
|
185
|
-
const { circleAttributes } = ((_a = this.state) === null || _a === void 0 ? void 0 : _a.layersData) || {};
|
|
186
|
-
if (totals && circleAttributes) {
|
|
187
|
-
const circleRadius = getOuterCircleRadiusByIndex(circleAttributes, info.index);
|
|
188
|
-
return Object.assign(Object.assign({}, commonInfo), { type: PickingType.LOCATION, object: location, id,
|
|
189
|
-
name,
|
|
190
|
-
totals, circleRadius: circleRadius, event: undefined });
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
return undefined;
|
|
195
|
-
});
|
|
196
|
-
}
|
|
197
|
-
_getHighlightedObject(info) {
|
|
198
|
-
var _a, _b;
|
|
199
|
-
const { index, sourceLayer } = info;
|
|
200
|
-
if (index < 0)
|
|
201
|
-
return undefined;
|
|
202
|
-
if (sourceLayer instanceof FlowLinesLayer ||
|
|
203
|
-
sourceLayer instanceof AnimatedFlowLinesLayer) {
|
|
204
|
-
const { lineAttributes } = ((_a = this.state) === null || _a === void 0 ? void 0 : _a.layersData) || {};
|
|
205
|
-
if (lineAttributes) {
|
|
206
|
-
let attrs = getFlowLineAttributesByIndex(lineAttributes, index);
|
|
207
|
-
if (this.props.fadeOpacityEnabled) {
|
|
208
|
-
attrs = Object.assign(Object.assign({}, attrs), { attributes: Object.assign(Object.assign({}, attrs.attributes), { getColor: Object.assign(Object.assign({}, attrs.attributes.getColor), { value: new Uint8Array([
|
|
209
|
-
...attrs.attributes.getColor.value.slice(0, 3),
|
|
210
|
-
255, // the highlight color should be always opaque
|
|
211
|
-
]) }) }) });
|
|
212
|
-
}
|
|
213
|
-
return {
|
|
214
|
-
type: HighlightType.FLOW,
|
|
215
|
-
lineAttributes: attrs,
|
|
216
|
-
};
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
else if (sourceLayer instanceof FlowCirclesLayer) {
|
|
220
|
-
const { circleAttributes } = ((_b = this.state) === null || _b === void 0 ? void 0 : _b.layersData) || {};
|
|
221
|
-
if (circleAttributes) {
|
|
222
|
-
return {
|
|
223
|
-
type: HighlightType.LOCATION,
|
|
224
|
-
centroid: getLocationCentroidByIndex(circleAttributes, index),
|
|
225
|
-
radius: getOuterCircleRadiusByIndex(circleAttributes, index),
|
|
226
|
-
};
|
|
227
|
-
}
|
|
228
|
-
}
|
|
229
|
-
return undefined;
|
|
230
|
-
}
|
|
231
|
-
renderLayers() {
|
|
232
|
-
var _a;
|
|
233
|
-
const layers = [];
|
|
234
|
-
if ((_a = this.state) === null || _a === void 0 ? void 0 : _a.layersData) {
|
|
235
|
-
const { layersData, highlightedObject } = this.state;
|
|
236
|
-
const { circleAttributes, lineAttributes } = layersData || {};
|
|
237
|
-
if (circleAttributes && lineAttributes) {
|
|
238
|
-
const flowMapColors = getFlowMapColors(this._getSettingsState());
|
|
239
|
-
const outlineColor = colorAsRgba(flowMapColors.outlineColor || (this.props.darkMode ? '#000' : '#fff'));
|
|
240
|
-
const commonLineLayerProps = {
|
|
241
|
-
data: lineAttributes,
|
|
242
|
-
parameters: Object.assign(Object.assign({}, this.props.parameters), {
|
|
243
|
-
// prevent z-fighting at non-zero bearing/pitch
|
|
244
|
-
depthTest: false }),
|
|
245
|
-
};
|
|
246
|
-
if (this.props.animationEnabled) {
|
|
247
|
-
layers.push(
|
|
248
|
-
// @ts-ignore
|
|
249
|
-
new AnimatedFlowLinesLayer(Object.assign({}, this.getSubLayerProps(Object.assign(Object.assign({}, commonLineLayerProps), { id: 'animated-flow-lines', drawOutline: false, thicknessUnit: 20 })))));
|
|
250
|
-
}
|
|
251
|
-
else {
|
|
252
|
-
layers.push(new FlowLinesLayer(Object.assign({}, this.getSubLayerProps(Object.assign(Object.assign({}, commonLineLayerProps), { id: 'flow-lines', drawOutline: true, outlineColor: outlineColor })))));
|
|
253
|
-
}
|
|
254
|
-
layers.push(new FlowCirclesLayer(this.getSubLayerProps({
|
|
255
|
-
id: 'circles',
|
|
256
|
-
data: circleAttributes,
|
|
257
|
-
emptyColor: [0, 0, 0, 255],
|
|
258
|
-
emptyOutlineColor: [0, 0, 0, 255],
|
|
259
|
-
})));
|
|
260
|
-
if (highlightedObject) {
|
|
261
|
-
switch (highlightedObject.type) {
|
|
262
|
-
case HighlightType.LOCATION:
|
|
263
|
-
layers.push(new ScatterplotLayer(Object.assign({}, this.getSubLayerProps({
|
|
264
|
-
id: 'location-highlight',
|
|
265
|
-
data: [highlightedObject],
|
|
266
|
-
pickable: false,
|
|
267
|
-
stroked: true,
|
|
268
|
-
filled: false,
|
|
269
|
-
lineWidthUnits: 'pixels',
|
|
270
|
-
getLineWidth: 2,
|
|
271
|
-
radiusUnits: 'pixels',
|
|
272
|
-
getRadius: (d) => d.radius,
|
|
273
|
-
getLineColor: colorAsRgba(this.props.highlightColor),
|
|
274
|
-
getPosition: (d) => d.centroid,
|
|
275
|
-
}))));
|
|
276
|
-
break;
|
|
277
|
-
case HighlightType.FLOW:
|
|
278
|
-
layers.push(new FlowLinesLayer(Object.assign({}, this.getSubLayerProps({
|
|
279
|
-
id: 'flow-highlight',
|
|
280
|
-
data: highlightedObject.lineAttributes,
|
|
281
|
-
drawOutline: true,
|
|
282
|
-
pickable: false,
|
|
283
|
-
outlineColor: colorAsRgba(this.props.highlightColor),
|
|
284
|
-
outlineThickness: 1,
|
|
285
|
-
}))));
|
|
286
|
-
break;
|
|
287
|
-
}
|
|
288
|
-
}
|
|
289
|
-
}
|
|
290
|
-
}
|
|
291
|
-
return layers;
|
|
292
|
-
}
|
|
293
|
-
}
|
|
294
|
-
FlowMapLayer.defaultProps = {
|
|
295
|
-
darkMode: true,
|
|
296
|
-
fadeAmount: 50,
|
|
297
|
-
locationTotalsEnabled: true,
|
|
298
|
-
animationEnabled: false,
|
|
299
|
-
clusteringEnabled: true,
|
|
300
|
-
fadeEnabled: true,
|
|
301
|
-
fadeOpacityEnabled: false,
|
|
302
|
-
clusteringAuto: true,
|
|
303
|
-
clusteringLevel: undefined,
|
|
304
|
-
adaptiveScalesEnabled: true,
|
|
305
|
-
colorScheme: 'Teal',
|
|
306
|
-
highlightColor: 'orange',
|
|
307
|
-
};
|
|
308
|
-
function asViewState(viewport) {
|
|
309
|
-
const { width, height, longitude, latitude, zoom, pitch, bearing } = viewport;
|
|
310
|
-
return {
|
|
311
|
-
width,
|
|
312
|
-
height,
|
|
313
|
-
longitude,
|
|
314
|
-
latitude,
|
|
315
|
-
zoom,
|
|
316
|
-
pitch,
|
|
317
|
-
bearing,
|
|
318
|
-
};
|
|
319
|
-
}
|
|
320
|
-
//# 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} from '@deck.gl/layers';\nimport {\n  colorAsRgba,\n  FlowLinesLayerAttributes,\n  FlowMapData,\n  FlowMapDataAccessors,\n  FlowMapDataProvider,\n  getFlowLineAttributesByIndex,\n  getFlowMapColors,\n  getOuterCircleRadiusByIndex,\n  getLocationCentroidByIndex,\n  isFlowMapData,\n  isFlowMapDataProvider,\n  LayersData,\n  LocalFlowMapDataProvider,\n  LocationFilterMode,\n  ViewportProps,\n  FlowMapAggregateAccessors,\n  ClusterNode,\n  AggregateFlow,\n} from '@flowmap.gl/data';\nimport AnimatedFlowLinesLayer from './AnimatedFlowLinesLayer';\nimport FlowCirclesLayer from './FlowCirclesLayer';\nimport FlowLinesLayer from './FlowLinesLayer';\nimport {\n  FlowLayerPickingInfo,\n  LayerProps,\n  PickingInfo,\n  PickingType,\n} from './types';\n\nexport type FlowMapLayerProps<L, F> = {\n  data: FlowMapData<L, F> | FlowMapDataProvider<L, F>;\n  locationTotalsEnabled?: 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;\n  highlightColor?: string;\n  onHover?: (\n    info: FlowLayerPickingInfo<L, F> | undefined,\n    event: SourceEvent,\n  ) => void;\n  onClick?: (info: FlowLayerPickingInfo<L, F>, event: SourceEvent) => void;\n} & Partial<FlowMapDataAccessors<L, F>> &\n  LayerProps;\n\nenum HighlightType {\n  LOCATION = 'location',\n  FLOW = 'flow',\n}\n\ntype HighlightedLocationObject = {\n  type: HighlightType.LOCATION;\n  centroid: [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};\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    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  };\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        // TODO: if (lastHoverEventStartTimeRef > startTime) {\n        //   // Skipping, because this is not the latest hover event\n        //   return;\n        // }\n        this.setState({highlightedObject: this._getHighlightedObject(info)});\n        const {onHover} = props;\n        if (onHover) {\n          this._getFlowLayerPickingInfo(info).then((info) =>\n            onHover(info, event),\n          );\n        }\n      },\n      onClick: (info: PickingInfo<any>, event: SourceEvent) => {\n        const {onClick} = props;\n        if (onClick) {\n          this._getFlowLayerPickingInfo(info).then((info) => {\n            if (info) {\n              onClick(info, event);\n            }\n          });\n        }\n      },\n    });\n  }\n\n  initializeState() {\n    this.state = {\n      accessors: new FlowMapAggregateAccessors<L, F>(this.props),\n      dataProvider: this._makeDataProvider(),\n      layersData: undefined,\n      highlightedObject: undefined,\n    };\n  }\n\n  private _updateAccessors() {\n    this.state?.dataProvider?.setAccessors(this.props);\n    this.setState({accessors: new FlowMapAggregateAccessors(this.props)});\n  }\n\n  private _makeDataProvider() {\n    const {data} = this.props;\n    if (isFlowMapDataProvider<L, F>(data)) {\n      return data;\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._makeDataProvider()});\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    const {dataProvider, highlightedObject} = this.state || {};\n    if (!dataProvider) {\n      return;\n    }\n\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({\n        highlightedObject: undefined,\n      });\n    }\n\n    if (changeFlags.viewportChanged || changeFlags.propsOrDataChanged) {\n      dataProvider.setFlowMapState(this._getFlowMapState());\n      (async () => {\n        const layersData = await dataProvider.getLayersData();\n        this.setState({layersData});\n      })();\n    }\n  }\n\n  private _getSettingsState() {\n    const {\n      locationTotalsEnabled,\n      adaptiveScalesEnabled,\n      animationEnabled,\n      clusteringEnabled,\n      clusteringLevel,\n      fadeEnabled,\n      fadeOpacityEnabled,\n      clusteringAuto,\n      darkMode,\n      fadeAmount,\n      colorScheme,\n    } = this.props;\n    return {\n      locationTotalsEnabled,\n      adaptiveScalesEnabled,\n      animationEnabled,\n      clusteringEnabled,\n      clusteringLevel,\n      fadeEnabled,\n      fadeOpacityEnabled,\n      clusteringAuto,\n      darkMode,\n      fadeAmount,\n      colorScheme,\n    };\n  }\n\n  private _getFlowMapState() {\n    return {\n      viewport: asViewState(this.context.viewport),\n      filterState: {\n        selectedLocations: undefined,\n        locationFilterMode: LocationFilterMode.ALL,\n        selectedTimeRange: undefined,\n      },\n      settingsState: this._getSettingsState(),\n    };\n  }\n\n  private async _getFlowLayerPickingInfo(\n    info: Record<string, any>,\n  ): Promise<FlowLayerPickingInfo<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      layer: info.layer,\n      index: info.index,\n      x: info.x,\n      y: info.y,\n      coordinate: info.coordinate,\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            type: PickingType.FLOW,\n            object: flow,\n            origin: origin,\n            dest: dest,\n            count: accessors.getFlowMagnitude(flow),\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            type: PickingType.LOCATION,\n            object: location,\n            id,\n            name,\n            totals,\n            circleRadius: circleRadius,\n            event: undefined,\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          centroid: getLocationCentroidByIndex(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} = 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: [0, 0, 0, 255],\n              emptyOutlineColor: [0, 0, 0, 255],\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                    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.centroid,\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                  }),\n                }),\n              );\n              break;\n          }\n        }\n      }\n    }\n\n    return layers;\n  }\n}\n\nfunction asViewState(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"]}
|