@fscharter/flowmap-layers 8.0.2-fsc.1
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/AnimatedFlowLinesLayer/AnimatedFlowLinesLayer.d.ts +76 -0
- package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayer.d.ts.map +1 -0
- package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayer.js +133 -0
- package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerFragment.glsl.d.ts +3 -0
- package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerFragment.glsl.d.ts.map +1 -0
- package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerFragment.glsl.js +25 -0
- package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerVertex.glsl.d.ts +3 -0
- package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerVertex.glsl.d.ts.map +1 -0
- package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerVertex.glsl.js +79 -0
- package/dist/AnimatedFlowLinesLayer/index.d.ts +3 -0
- package/dist/AnimatedFlowLinesLayer/index.d.ts.map +1 -0
- package/dist/AnimatedFlowLinesLayer/index.js +8 -0
- package/dist/FlowCirclesLayer/FlowCirclesLayer.d.ts +59 -0
- package/dist/FlowCirclesLayer/FlowCirclesLayer.d.ts.map +1 -0
- package/dist/FlowCirclesLayer/FlowCirclesLayer.js +106 -0
- package/dist/FlowCirclesLayer/FlowCirclesLayerFragment.glsl.d.ts +3 -0
- package/dist/FlowCirclesLayer/FlowCirclesLayerFragment.glsl.d.ts.map +1 -0
- package/dist/FlowCirclesLayer/FlowCirclesLayerFragment.glsl.js +65 -0
- package/dist/FlowCirclesLayer/FlowCirclesLayerVertex.glsl.d.ts +3 -0
- package/dist/FlowCirclesLayer/FlowCirclesLayerVertex.glsl.d.ts.map +1 -0
- package/dist/FlowCirclesLayer/FlowCirclesLayerVertex.glsl.js +51 -0
- package/dist/FlowCirclesLayer/index.d.ts +3 -0
- package/dist/FlowCirclesLayer/index.d.ts.map +1 -0
- package/dist/FlowCirclesLayer/index.js +8 -0
- package/dist/FlowLinesLayer/FlowLinesLayer.d.ts +64 -0
- package/dist/FlowLinesLayer/FlowLinesLayer.d.ts.map +1 -0
- package/dist/FlowLinesLayer/FlowLinesLayer.js +188 -0
- package/dist/FlowLinesLayer/FlowLinesLayerFragment.glsl.d.ts +3 -0
- package/dist/FlowLinesLayer/FlowLinesLayerFragment.glsl.d.ts.map +1 -0
- package/dist/FlowLinesLayer/FlowLinesLayerFragment.glsl.js +24 -0
- package/dist/FlowLinesLayer/FlowLinesLayerVertex.glsl.d.ts +3 -0
- package/dist/FlowLinesLayer/FlowLinesLayerVertex.glsl.d.ts.map +1 -0
- package/dist/FlowLinesLayer/FlowLinesLayerVertex.glsl.js +86 -0
- package/dist/FlowLinesLayer/index.d.ts +3 -0
- package/dist/FlowLinesLayer/index.d.ts.map +1 -0
- package/dist/FlowLinesLayer/index.js +8 -0
- package/dist/FlowmapLayer.d.ts +87 -0
- package/dist/FlowmapLayer.d.ts.map +1 -0
- package/dist/FlowmapLayer.js +434 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +11 -0
- package/dist/types.d.ts +36 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +25 -0
- package/package.json +29 -0
- package/src/AnimatedFlowLinesLayer/AnimatedFlowLinesLayer.ts +177 -0
- package/src/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerFragment.glsl.ts +25 -0
- package/src/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerVertex.glsl.ts +78 -0
- package/src/AnimatedFlowLinesLayer/index.ts +9 -0
- package/src/FlowCirclesLayer/FlowCirclesLayer.ts +138 -0
- package/src/FlowCirclesLayer/FlowCirclesLayerFragment.glsl.ts +64 -0
- package/src/FlowCirclesLayer/FlowCirclesLayerVertex.glsl.ts +50 -0
- package/src/FlowCirclesLayer/index.ts +9 -0
- package/src/FlowLinesLayer/FlowLinesLayer.ts +232 -0
- package/src/FlowLinesLayer/FlowLinesLayerFragment.glsl.ts +23 -0
- package/src/FlowLinesLayer/FlowLinesLayerVertex.glsl.ts +85 -0
- package/src/FlowLinesLayer/index.ts +9 -0
- package/src/FlowmapLayer.ts +587 -0
- package/src/index.ts +13 -0
- package/src/types.ts +80 -0
- package/tsconfig.json +11 -0
- package/typings.d.ts +4 -0
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { CompositeLayer } from '@deck.gl/core';
|
|
2
|
+
import { FilterState, FlowEndpointsInViewportMode, FlowLinesLayerAttributes, FlowmapAggregateAccessors, FlowmapData, FlowmapDataAccessors, FlowmapDataProvider, LayersData } from '@flowmap.gl/data';
|
|
3
|
+
import { FlowmapLayerPickingInfo, LayerProps } from './types';
|
|
4
|
+
export type FlowmapLayerProps<L extends Record<string, any>, F extends Record<string, any>> = {
|
|
5
|
+
data?: FlowmapData<L, F>;
|
|
6
|
+
dataProvider?: FlowmapDataProvider<L, F>;
|
|
7
|
+
filter?: FilterState;
|
|
8
|
+
locationsEnabled?: boolean;
|
|
9
|
+
locationTotalsEnabled?: boolean;
|
|
10
|
+
locationLabelsEnabled?: boolean;
|
|
11
|
+
adaptiveScalesEnabled?: boolean;
|
|
12
|
+
animationEnabled?: boolean;
|
|
13
|
+
clusteringEnabled?: boolean;
|
|
14
|
+
clusteringLevel?: number;
|
|
15
|
+
fadeEnabled?: boolean;
|
|
16
|
+
fadeOpacityEnabled?: boolean;
|
|
17
|
+
clusteringAuto?: boolean;
|
|
18
|
+
darkMode?: boolean;
|
|
19
|
+
fadeAmount?: number;
|
|
20
|
+
colorScheme?: string | string[];
|
|
21
|
+
highlightColor?: string | number[];
|
|
22
|
+
maxTopFlowsDisplayNum?: number;
|
|
23
|
+
flowEndpointsInViewportMode?: FlowEndpointsInViewportMode;
|
|
24
|
+
onHover?: (info: FlowmapLayerPickingInfo<L, F> | undefined, event: SourceEvent) => void;
|
|
25
|
+
onClick?: (info: FlowmapLayerPickingInfo<L, F>, event: SourceEvent) => void;
|
|
26
|
+
} & Partial<FlowmapDataAccessors<L, F>> & LayerProps;
|
|
27
|
+
declare enum HighlightType {
|
|
28
|
+
LOCATION = "location",
|
|
29
|
+
FLOW = "flow"
|
|
30
|
+
}
|
|
31
|
+
type HighlightedLocationObject = {
|
|
32
|
+
type: HighlightType.LOCATION;
|
|
33
|
+
coords: [number, number];
|
|
34
|
+
radius: number;
|
|
35
|
+
};
|
|
36
|
+
type HighlightedFlowObject = {
|
|
37
|
+
type: HighlightType.FLOW;
|
|
38
|
+
lineAttributes: FlowLinesLayerAttributes;
|
|
39
|
+
};
|
|
40
|
+
type HighlightedObject = HighlightedLocationObject | HighlightedFlowObject;
|
|
41
|
+
type State<L extends Record<string, any>, F extends Record<string, any>> = {
|
|
42
|
+
accessors: FlowmapAggregateAccessors<L, F>;
|
|
43
|
+
dataProvider: FlowmapDataProvider<L, F>;
|
|
44
|
+
layersData: LayersData | undefined;
|
|
45
|
+
highlightedObject: HighlightedObject | undefined;
|
|
46
|
+
pickingInfo: FlowmapLayerPickingInfo<L, F> | undefined;
|
|
47
|
+
lastHoverTime: number | undefined;
|
|
48
|
+
lastClickTime: number | undefined;
|
|
49
|
+
};
|
|
50
|
+
export type SourceEvent = {
|
|
51
|
+
srcEvent: MouseEvent;
|
|
52
|
+
};
|
|
53
|
+
export default class FlowmapLayer<L extends Record<string, any>, F extends Record<string, any>> extends CompositeLayer {
|
|
54
|
+
static defaultProps: {
|
|
55
|
+
darkMode: boolean;
|
|
56
|
+
fadeAmount: number;
|
|
57
|
+
locationsEnabled: boolean;
|
|
58
|
+
locationTotalsEnabled: boolean;
|
|
59
|
+
locationLabelsEnabled: boolean;
|
|
60
|
+
animationEnabled: boolean;
|
|
61
|
+
clusteringEnabled: boolean;
|
|
62
|
+
fadeEnabled: boolean;
|
|
63
|
+
fadeOpacityEnabled: boolean;
|
|
64
|
+
clusteringAuto: boolean;
|
|
65
|
+
clusteringLevel: undefined;
|
|
66
|
+
adaptiveScalesEnabled: boolean;
|
|
67
|
+
colorScheme: string;
|
|
68
|
+
highlightColor: string;
|
|
69
|
+
maxTopFlowsDisplayNum: number;
|
|
70
|
+
flowEndpointsInViewportMode: string;
|
|
71
|
+
};
|
|
72
|
+
state: State<L, F> | undefined;
|
|
73
|
+
constructor(props: FlowmapLayerProps<L, F>);
|
|
74
|
+
initializeState(): void;
|
|
75
|
+
getPickingInfo({ info }: Record<string, any>): any;
|
|
76
|
+
private _getOrMakeDataProvider;
|
|
77
|
+
private _updateDataProvider;
|
|
78
|
+
shouldUpdateState(params: Record<string, any>): boolean;
|
|
79
|
+
updateState({ oldProps, props, changeFlags }: Record<string, any>): void;
|
|
80
|
+
private _getSettingsState;
|
|
81
|
+
private _getFlowmapState;
|
|
82
|
+
private _getFlowmapLayerPickingInfo;
|
|
83
|
+
private _getHighlightedObject;
|
|
84
|
+
renderLayers(): Array<any>;
|
|
85
|
+
}
|
|
86
|
+
export {};
|
|
87
|
+
//# sourceMappingURL=FlowmapLayer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FlowmapLayer.d.ts","sourceRoot":"","sources":["../src/FlowmapLayer.ts"],"names":[],"mappings":"AAKA,OAAO,EAAC,cAAc,EAAC,MAAM,eAAe,CAAC;AAE7C,OAAO,EACL,WAAW,EACX,2BAA2B,EAC3B,wBAAwB,EACxB,yBAAyB,EACzB,WAAW,EACX,oBAAoB,EACpB,mBAAmB,EACnB,UAAU,EAUX,MAAM,kBAAkB,CAAC;AAI1B,OAAO,EACL,uBAAuB,EACvB,UAAU,EAGX,MAAM,SAAS,CAAC;AAEjB,MAAM,MAAM,iBAAiB,CAC3B,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAC7B,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,IAC3B;IACF,IAAI,CAAC,EAAE,WAAW,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACzB,YAAY,CAAC,EAAE,mBAAmB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACzC,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAChC,cAAc,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IACnC,qBAAqB,CAAC,EAAE,MAAM,CAAC;IAC/B,2BAA2B,CAAC,EAAE,2BAA2B,CAAC;IAC1D,OAAO,CAAC,EAAE,CACR,IAAI,EAAE,uBAAuB,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,SAAS,EAC/C,KAAK,EAAE,WAAW,KACf,IAAI,CAAC;IACV,OAAO,CAAC,EAAE,CAAC,IAAI,EAAE,uBAAuB,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,WAAW,KAAK,IAAI,CAAC;CAC7E,GAAG,OAAO,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GACrC,UAAU,CAAC;AAsBb,aAAK,aAAa;IAChB,QAAQ,aAAa;IACrB,IAAI,SAAS;CACd;AAED,KAAK,yBAAyB,GAAG;IAC/B,IAAI,EAAE,aAAa,CAAC,QAAQ,CAAC;IAC7B,MAAM,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACzB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,KAAK,qBAAqB,GAAG;IAC3B,IAAI,EAAE,aAAa,CAAC,IAAI,CAAC;IACzB,cAAc,EAAE,wBAAwB,CAAC;CAC1C,CAAC;AAEF,KAAK,iBAAiB,GAAG,yBAAyB,GAAG,qBAAqB,CAAC;AAE3E,KAAK,KAAK,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,IAAI;IACzE,SAAS,EAAE,yBAAyB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC3C,YAAY,EAAE,mBAAmB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACxC,UAAU,EAAE,UAAU,GAAG,SAAS,CAAC;IACnC,iBAAiB,EAAE,iBAAiB,GAAG,SAAS,CAAC;IACjD,WAAW,EAAE,uBAAuB,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,SAAS,CAAC;IACvD,aAAa,EAAE,MAAM,GAAG,SAAS,CAAC;IAClC,aAAa,EAAE,MAAM,GAAG,SAAS,CAAC;CACnC,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG;IAAC,QAAQ,EAAE,UAAU,CAAA;CAAC,CAAC;AAEjD,MAAM,CAAC,OAAO,OAAO,YAAY,CAC/B,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAC7B,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAC7B,SAAQ,cAAc;IACtB,MAAM,CAAC,YAAY;;;;;;;;;;;;;;;;;MAiBjB;IACF,KAAK,EAAE,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,SAAS,CAAC;gBAEZ,KAAK,EAAE,iBAAiB,CAAC,CAAC,EAAE,CAAC,CAAC;IA4CjD,eAAe;IAYf,cAAc,CAAC,EAAC,IAAI,EAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAoB1C,OAAO,CAAC,sBAAsB;IAc9B,OAAO,CAAC,mBAAmB;IAI3B,iBAAiB,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,OAAO;IAavD,WAAW,CAAC,EAAC,QAAQ,EAAE,KAAK,EAAE,WAAW,EAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,IAAI;IA6BtE,OAAO,CAAC,iBAAiB;IAuCzB,OAAO,CAAC,gBAAgB;YAQV,2BAA2B;IA4EzC,OAAO,CAAC,qBAAqB;IA6C7B,YAAY,IAAI,KAAK,CAAC,GAAG,CAAC;CAgI3B"}
|
|
@@ -0,0 +1,434 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) Flowmap.gl contributors
|
|
3
|
+
* Copyright (c) 2018-2020 Teralytics
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { CompositeLayer } from '@deck.gl/core';
|
|
7
|
+
import { ScatterplotLayer, TextLayer } from '@deck.gl/layers';
|
|
8
|
+
import { FlowmapAggregateAccessors, LocalFlowmapDataProvider, colorAsRgba, getFlowLineAttributesByIndex, getFlowmapColors, getLocationCoordsByIndex, getOuterCircleRadiusByIndex, isFlowmapData, isFlowmapDataProvider, } from '@flowmap.gl/data';
|
|
9
|
+
import AnimatedFlowLinesLayer from './AnimatedFlowLinesLayer';
|
|
10
|
+
import FlowCirclesLayer from './FlowCirclesLayer';
|
|
11
|
+
import FlowLinesLayer from './FlowLinesLayer';
|
|
12
|
+
import { PickingType, } from './types';
|
|
13
|
+
const PROPS_TO_CAUSE_LAYER_DATA_UPDATE = [
|
|
14
|
+
'filter',
|
|
15
|
+
'locationsEnabled',
|
|
16
|
+
'locationTotalsEnabled',
|
|
17
|
+
'locationLabelsEnabled',
|
|
18
|
+
'adaptiveScalesEnabled',
|
|
19
|
+
'animationEnabled',
|
|
20
|
+
'clusteringEnabled',
|
|
21
|
+
'clusteringLevel',
|
|
22
|
+
'fadeEnabled',
|
|
23
|
+
'fadeOpacityEnabled',
|
|
24
|
+
'clusteringAuto',
|
|
25
|
+
'darkMode',
|
|
26
|
+
'fadeAmount',
|
|
27
|
+
'colorScheme',
|
|
28
|
+
'highlightColor',
|
|
29
|
+
'maxTopFlowsDisplayNum',
|
|
30
|
+
'flowEndpointsInViewportMode',
|
|
31
|
+
];
|
|
32
|
+
var HighlightType;
|
|
33
|
+
(function (HighlightType) {
|
|
34
|
+
HighlightType["LOCATION"] = "location";
|
|
35
|
+
HighlightType["FLOW"] = "flow";
|
|
36
|
+
})(HighlightType || (HighlightType = {}));
|
|
37
|
+
class FlowmapLayer extends CompositeLayer {
|
|
38
|
+
constructor(props) {
|
|
39
|
+
super({
|
|
40
|
+
...props,
|
|
41
|
+
onHover: (info, event) => {
|
|
42
|
+
const startTime = Date.now();
|
|
43
|
+
this.setState({
|
|
44
|
+
highlightedObject: this._getHighlightedObject(info),
|
|
45
|
+
lastHoverTime: startTime,
|
|
46
|
+
});
|
|
47
|
+
const { onHover } = props;
|
|
48
|
+
if (onHover) {
|
|
49
|
+
this._getFlowmapLayerPickingInfo(info).then((info) => {
|
|
50
|
+
if ((this.state?.lastHoverTime ?? 0) <= startTime) {
|
|
51
|
+
this.setState({ pickingInfo: info });
|
|
52
|
+
onHover(info, event);
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
// Skipping, because this is not the latest hover event
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
onClick: (info, event) => {
|
|
61
|
+
const { onClick } = props;
|
|
62
|
+
const startTime = Date.now();
|
|
63
|
+
this.setState({
|
|
64
|
+
lastClickTime: startTime,
|
|
65
|
+
});
|
|
66
|
+
if (onClick) {
|
|
67
|
+
this._getFlowmapLayerPickingInfo(info).then((info) => {
|
|
68
|
+
if ((this.state?.lastClickTime ?? 0) <= startTime) {
|
|
69
|
+
this.setState({ pickingInfo: info });
|
|
70
|
+
if (info) {
|
|
71
|
+
onClick(info, event);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
// Skipping, because this is not the latest hover event
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
},
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
initializeState() {
|
|
83
|
+
this.state = {
|
|
84
|
+
accessors: new FlowmapAggregateAccessors(this.props),
|
|
85
|
+
dataProvider: this._getOrMakeDataProvider(),
|
|
86
|
+
layersData: undefined,
|
|
87
|
+
highlightedObject: undefined,
|
|
88
|
+
pickingInfo: undefined,
|
|
89
|
+
lastHoverTime: undefined,
|
|
90
|
+
lastClickTime: undefined,
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
getPickingInfo({ info }) {
|
|
94
|
+
// This is for onHover event handlers set on the <DeckGL> component
|
|
95
|
+
if (!info.object) {
|
|
96
|
+
const object = this.state?.pickingInfo?.object;
|
|
97
|
+
if (object) {
|
|
98
|
+
return {
|
|
99
|
+
...info,
|
|
100
|
+
object,
|
|
101
|
+
picked: true,
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
return info;
|
|
106
|
+
}
|
|
107
|
+
// private _updateAccessors() {
|
|
108
|
+
// this.state?.dataProvider?.setAccessors(this.props);
|
|
109
|
+
// this.setState({accessors: new FlowmapAggregateAccessors(this.props)});
|
|
110
|
+
// }
|
|
111
|
+
_getOrMakeDataProvider() {
|
|
112
|
+
const { data, dataProvider } = this.props;
|
|
113
|
+
if (isFlowmapDataProvider(dataProvider)) {
|
|
114
|
+
return dataProvider;
|
|
115
|
+
}
|
|
116
|
+
else if (isFlowmapData(data)) {
|
|
117
|
+
const dataProvider = new LocalFlowmapDataProvider(this.props);
|
|
118
|
+
dataProvider.setFlowmapData(data);
|
|
119
|
+
return dataProvider;
|
|
120
|
+
}
|
|
121
|
+
throw new Error('FlowmapLayer: data must be a FlowmapDataProvider or FlowmapData');
|
|
122
|
+
}
|
|
123
|
+
_updateDataProvider() {
|
|
124
|
+
this.setState({ dataProvider: this._getOrMakeDataProvider() });
|
|
125
|
+
}
|
|
126
|
+
shouldUpdateState(params) {
|
|
127
|
+
const { changeFlags } = params;
|
|
128
|
+
// if (this._viewportChanged()) {
|
|
129
|
+
// return true;
|
|
130
|
+
// }
|
|
131
|
+
if (changeFlags.viewportChanged) {
|
|
132
|
+
return true;
|
|
133
|
+
}
|
|
134
|
+
return super.shouldUpdateState(params);
|
|
135
|
+
// TODO: be smarter on when to update
|
|
136
|
+
// (e.g. ignore viewport changes when adaptiveScalesEnabled and clustering are false)
|
|
137
|
+
}
|
|
138
|
+
updateState({ oldProps, props, changeFlags }) {
|
|
139
|
+
if (changeFlags.propsChanged) {
|
|
140
|
+
// this._updateAccessors();
|
|
141
|
+
}
|
|
142
|
+
if (changeFlags.dataChanged) {
|
|
143
|
+
this._updateDataProvider();
|
|
144
|
+
}
|
|
145
|
+
if (changeFlags.viewportChanged || changeFlags.dataChanged) {
|
|
146
|
+
this.setState({ highlightedObject: undefined });
|
|
147
|
+
}
|
|
148
|
+
if (changeFlags.viewportChanged ||
|
|
149
|
+
changeFlags.dataChanged ||
|
|
150
|
+
(changeFlags.propsChanged &&
|
|
151
|
+
PROPS_TO_CAUSE_LAYER_DATA_UPDATE.some((prop) => oldProps[prop] !== props[prop]))) {
|
|
152
|
+
const { dataProvider } = this.state || {};
|
|
153
|
+
if (dataProvider) {
|
|
154
|
+
dataProvider.setFlowmapState(this._getFlowmapState());
|
|
155
|
+
dataProvider.updateLayersData((layersData) => {
|
|
156
|
+
this.setState({ layersData, highlightedObject: undefined });
|
|
157
|
+
}, changeFlags);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
_getSettingsState() {
|
|
162
|
+
const { locationsEnabled, locationTotalsEnabled, locationLabelsEnabled, adaptiveScalesEnabled, animationEnabled, clusteringEnabled, clusteringLevel, fadeEnabled, fadeOpacityEnabled, clusteringAuto, darkMode, fadeAmount, colorScheme, highlightColor, maxTopFlowsDisplayNum, flowEndpointsInViewportMode, } = this.props;
|
|
163
|
+
return {
|
|
164
|
+
locationsEnabled,
|
|
165
|
+
locationTotalsEnabled,
|
|
166
|
+
locationLabelsEnabled,
|
|
167
|
+
adaptiveScalesEnabled,
|
|
168
|
+
animationEnabled,
|
|
169
|
+
clusteringEnabled,
|
|
170
|
+
clusteringLevel,
|
|
171
|
+
fadeEnabled,
|
|
172
|
+
fadeOpacityEnabled,
|
|
173
|
+
clusteringAuto,
|
|
174
|
+
darkMode,
|
|
175
|
+
fadeAmount,
|
|
176
|
+
colorScheme,
|
|
177
|
+
highlightColor,
|
|
178
|
+
maxTopFlowsDisplayNum,
|
|
179
|
+
flowEndpointsInViewportMode,
|
|
180
|
+
};
|
|
181
|
+
}
|
|
182
|
+
_getFlowmapState() {
|
|
183
|
+
return {
|
|
184
|
+
viewport: pickViewportProps(this.context.viewport),
|
|
185
|
+
filter: this.props.filter,
|
|
186
|
+
settings: this._getSettingsState(),
|
|
187
|
+
};
|
|
188
|
+
}
|
|
189
|
+
async _getFlowmapLayerPickingInfo(info) {
|
|
190
|
+
const { index, sourceLayer } = info;
|
|
191
|
+
const { dataProvider, accessors } = this.state || {};
|
|
192
|
+
if (!dataProvider || !accessors) {
|
|
193
|
+
return undefined;
|
|
194
|
+
}
|
|
195
|
+
const commonInfo = {
|
|
196
|
+
...info,
|
|
197
|
+
picked: info.picked,
|
|
198
|
+
layer: info.layer,
|
|
199
|
+
index: info.index,
|
|
200
|
+
x: info.x,
|
|
201
|
+
y: info.y,
|
|
202
|
+
coordinate: info.coordinate,
|
|
203
|
+
event: info.event,
|
|
204
|
+
};
|
|
205
|
+
if (sourceLayer instanceof FlowLinesLayer ||
|
|
206
|
+
sourceLayer instanceof AnimatedFlowLinesLayer) {
|
|
207
|
+
const flow = index === -1 ? undefined : await dataProvider.getFlowByIndex(index);
|
|
208
|
+
if (flow) {
|
|
209
|
+
const origin = await dataProvider.getLocationById(accessors.getFlowOriginId(flow));
|
|
210
|
+
const dest = await dataProvider.getLocationById(accessors.getFlowDestId(flow));
|
|
211
|
+
if (origin && dest) {
|
|
212
|
+
return {
|
|
213
|
+
...commonInfo,
|
|
214
|
+
object: {
|
|
215
|
+
type: PickingType.FLOW,
|
|
216
|
+
flow,
|
|
217
|
+
origin: origin,
|
|
218
|
+
dest: dest,
|
|
219
|
+
count: accessors.getFlowMagnitude(flow),
|
|
220
|
+
},
|
|
221
|
+
};
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
else if (sourceLayer instanceof FlowCirclesLayer) {
|
|
226
|
+
const location = index === -1 ? undefined : await dataProvider.getLocationByIndex(index);
|
|
227
|
+
if (location) {
|
|
228
|
+
const id = accessors.getLocationId(location);
|
|
229
|
+
const name = accessors.getLocationName(location);
|
|
230
|
+
const totals = await dataProvider.getTotalsForLocation(id);
|
|
231
|
+
const { circleAttributes } = this.state?.layersData || {};
|
|
232
|
+
if (totals && circleAttributes) {
|
|
233
|
+
const circleRadius = getOuterCircleRadiusByIndex(circleAttributes, info.index);
|
|
234
|
+
return {
|
|
235
|
+
...commonInfo,
|
|
236
|
+
object: {
|
|
237
|
+
type: PickingType.LOCATION,
|
|
238
|
+
location,
|
|
239
|
+
id,
|
|
240
|
+
name,
|
|
241
|
+
totals,
|
|
242
|
+
circleRadius: circleRadius,
|
|
243
|
+
},
|
|
244
|
+
};
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
return undefined;
|
|
249
|
+
}
|
|
250
|
+
_getHighlightedObject(info) {
|
|
251
|
+
const { index, sourceLayer } = info;
|
|
252
|
+
if (index < 0)
|
|
253
|
+
return undefined;
|
|
254
|
+
if (sourceLayer instanceof FlowLinesLayer ||
|
|
255
|
+
sourceLayer instanceof AnimatedFlowLinesLayer) {
|
|
256
|
+
const { lineAttributes } = this.state?.layersData || {};
|
|
257
|
+
if (lineAttributes) {
|
|
258
|
+
let attrs = getFlowLineAttributesByIndex(lineAttributes, index);
|
|
259
|
+
if (this.props.fadeOpacityEnabled) {
|
|
260
|
+
attrs = {
|
|
261
|
+
...attrs,
|
|
262
|
+
attributes: {
|
|
263
|
+
...attrs.attributes,
|
|
264
|
+
getColor: {
|
|
265
|
+
...attrs.attributes.getColor,
|
|
266
|
+
value: new Uint8Array([
|
|
267
|
+
...attrs.attributes.getColor.value.slice(0, 3),
|
|
268
|
+
255, // the highlight color should be always opaque
|
|
269
|
+
]),
|
|
270
|
+
},
|
|
271
|
+
},
|
|
272
|
+
};
|
|
273
|
+
}
|
|
274
|
+
return {
|
|
275
|
+
type: HighlightType.FLOW,
|
|
276
|
+
lineAttributes: attrs,
|
|
277
|
+
};
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
else if (sourceLayer instanceof FlowCirclesLayer) {
|
|
281
|
+
const { circleAttributes } = this.state?.layersData || {};
|
|
282
|
+
if (circleAttributes) {
|
|
283
|
+
return {
|
|
284
|
+
type: HighlightType.LOCATION,
|
|
285
|
+
coords: getLocationCoordsByIndex(circleAttributes, index),
|
|
286
|
+
radius: getOuterCircleRadiusByIndex(circleAttributes, index),
|
|
287
|
+
};
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
return undefined;
|
|
291
|
+
}
|
|
292
|
+
renderLayers() {
|
|
293
|
+
const layers = [];
|
|
294
|
+
if (this.state?.layersData) {
|
|
295
|
+
const { layersData, highlightedObject } = this.state;
|
|
296
|
+
const { circleAttributes, lineAttributes, locationLabels } = layersData || {};
|
|
297
|
+
if (circleAttributes && lineAttributes) {
|
|
298
|
+
const flowmapColors = getFlowmapColors(this._getSettingsState());
|
|
299
|
+
const outlineColor = colorAsRgba(flowmapColors.outlineColor || (this.props.darkMode ? '#000' : '#fff'));
|
|
300
|
+
const commonLineLayerProps = {
|
|
301
|
+
data: lineAttributes,
|
|
302
|
+
parameters: {
|
|
303
|
+
...this.props.parameters,
|
|
304
|
+
// prevent z-fighting at non-zero bearing/pitch
|
|
305
|
+
depthTest: false,
|
|
306
|
+
},
|
|
307
|
+
};
|
|
308
|
+
if (this.props.animationEnabled) {
|
|
309
|
+
layers.push(
|
|
310
|
+
// @ts-ignore
|
|
311
|
+
new AnimatedFlowLinesLayer({
|
|
312
|
+
...this.getSubLayerProps({
|
|
313
|
+
...commonLineLayerProps,
|
|
314
|
+
id: 'animated-flow-lines',
|
|
315
|
+
drawOutline: false,
|
|
316
|
+
thicknessUnit: 20,
|
|
317
|
+
}),
|
|
318
|
+
}));
|
|
319
|
+
}
|
|
320
|
+
else {
|
|
321
|
+
layers.push(new FlowLinesLayer({
|
|
322
|
+
...this.getSubLayerProps({
|
|
323
|
+
...commonLineLayerProps,
|
|
324
|
+
id: 'flow-lines',
|
|
325
|
+
drawOutline: true,
|
|
326
|
+
outlineColor: outlineColor,
|
|
327
|
+
}),
|
|
328
|
+
}));
|
|
329
|
+
}
|
|
330
|
+
layers.push(new FlowCirclesLayer(this.getSubLayerProps({
|
|
331
|
+
id: 'circles',
|
|
332
|
+
data: circleAttributes,
|
|
333
|
+
emptyColor: this.props.darkMode
|
|
334
|
+
? [0, 0, 0, 255]
|
|
335
|
+
: [255, 255, 255, 255],
|
|
336
|
+
outlineEmptyMix: 0.4,
|
|
337
|
+
})));
|
|
338
|
+
if (highlightedObject) {
|
|
339
|
+
switch (highlightedObject.type) {
|
|
340
|
+
case HighlightType.LOCATION:
|
|
341
|
+
layers.push(new ScatterplotLayer({
|
|
342
|
+
...this.getSubLayerProps({
|
|
343
|
+
id: 'location-highlight',
|
|
344
|
+
data: [highlightedObject],
|
|
345
|
+
pickable: false,
|
|
346
|
+
antialiasing: true,
|
|
347
|
+
stroked: true,
|
|
348
|
+
filled: false,
|
|
349
|
+
lineWidthUnits: 'pixels',
|
|
350
|
+
getLineWidth: 2,
|
|
351
|
+
radiusUnits: 'pixels',
|
|
352
|
+
getRadius: (d) => d.radius,
|
|
353
|
+
getLineColor: colorAsRgba(this.props.highlightColor),
|
|
354
|
+
getPosition: (d) => d.coords,
|
|
355
|
+
}),
|
|
356
|
+
}));
|
|
357
|
+
break;
|
|
358
|
+
case HighlightType.FLOW:
|
|
359
|
+
layers.push(new FlowLinesLayer({
|
|
360
|
+
...this.getSubLayerProps({
|
|
361
|
+
id: 'flow-highlight',
|
|
362
|
+
data: highlightedObject.lineAttributes,
|
|
363
|
+
drawOutline: true,
|
|
364
|
+
pickable: false,
|
|
365
|
+
outlineColor: colorAsRgba(this.props.highlightColor),
|
|
366
|
+
outlineThickness: 1,
|
|
367
|
+
parameters: {
|
|
368
|
+
depthTest: false,
|
|
369
|
+
},
|
|
370
|
+
}),
|
|
371
|
+
}));
|
|
372
|
+
break;
|
|
373
|
+
}
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
if (locationLabels) {
|
|
377
|
+
layers.push(new TextLayer(this.getSubLayerProps({
|
|
378
|
+
id: 'location-labels',
|
|
379
|
+
data: locationLabels,
|
|
380
|
+
maxWidth: 1000,
|
|
381
|
+
pickable: false,
|
|
382
|
+
fontFamily: 'Helvetica',
|
|
383
|
+
getPixelOffset: (d, { index }) => {
|
|
384
|
+
const r = getOuterCircleRadiusByIndex(circleAttributes, index);
|
|
385
|
+
return [0, r + 5];
|
|
386
|
+
},
|
|
387
|
+
getPosition: (d, { index }) => {
|
|
388
|
+
const pos = getLocationCoordsByIndex(circleAttributes, index);
|
|
389
|
+
return pos;
|
|
390
|
+
},
|
|
391
|
+
getText: (d) => d,
|
|
392
|
+
getSize: 10,
|
|
393
|
+
getColor: [255, 255, 255, 255],
|
|
394
|
+
getAngle: 0,
|
|
395
|
+
getTextAnchor: 'middle',
|
|
396
|
+
getAlignmentBaseline: 'top',
|
|
397
|
+
})));
|
|
398
|
+
}
|
|
399
|
+
}
|
|
400
|
+
return layers;
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
FlowmapLayer.defaultProps = {
|
|
404
|
+
darkMode: true,
|
|
405
|
+
fadeAmount: 50,
|
|
406
|
+
locationsEnabled: true,
|
|
407
|
+
locationTotalsEnabled: true,
|
|
408
|
+
locationLabelsEnabled: false,
|
|
409
|
+
animationEnabled: false,
|
|
410
|
+
clusteringEnabled: true,
|
|
411
|
+
fadeEnabled: true,
|
|
412
|
+
fadeOpacityEnabled: false,
|
|
413
|
+
clusteringAuto: true,
|
|
414
|
+
clusteringLevel: undefined,
|
|
415
|
+
adaptiveScalesEnabled: true,
|
|
416
|
+
colorScheme: 'Teal',
|
|
417
|
+
highlightColor: 'orange',
|
|
418
|
+
maxTopFlowsDisplayNum: 5000,
|
|
419
|
+
flowEndpointsInViewportMode: 'any',
|
|
420
|
+
};
|
|
421
|
+
export default FlowmapLayer;
|
|
422
|
+
function pickViewportProps(viewport) {
|
|
423
|
+
const { width, height, longitude, latitude, zoom, pitch, bearing } = viewport;
|
|
424
|
+
return {
|
|
425
|
+
width,
|
|
426
|
+
height,
|
|
427
|
+
longitude,
|
|
428
|
+
latitude,
|
|
429
|
+
zoom,
|
|
430
|
+
pitch,
|
|
431
|
+
bearing,
|
|
432
|
+
};
|
|
433
|
+
}
|
|
434
|
+
//# 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  FilterState,\n  FlowEndpointsInViewportMode,\n  FlowLinesLayerAttributes,\n  FlowmapAggregateAccessors,\n  FlowmapData,\n  FlowmapDataAccessors,\n  FlowmapDataProvider,\n  LayersData,\n  LocalFlowmapDataProvider,\n  ViewportProps,\n  colorAsRgba,\n  getFlowLineAttributesByIndex,\n  getFlowmapColors,\n  getLocationCoordsByIndex,\n  getOuterCircleRadiusByIndex,\n  isFlowmapData,\n  isFlowmapDataProvider,\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  flowEndpointsInViewportMode?: FlowEndpointsInViewportMode;\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  'flowEndpointsInViewportMode',\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    flowEndpointsInViewportMode: 'any',\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      flowEndpointsInViewportMode,\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      flowEndpointsInViewportMode,\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
ADDED
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { default as AnimatedFlowLinesLayer } from './AnimatedFlowLinesLayer';
|
|
2
|
+
export { default as FlowLinesLayer } from './FlowLinesLayer';
|
|
3
|
+
export { default as FlowCirclesLayer } from './FlowCirclesLayer';
|
|
4
|
+
export { default as FlowmapLayer } from './FlowmapLayer';
|
|
5
|
+
export type { FlowmapLayerProps } from './FlowmapLayer';
|
|
6
|
+
export * from './types';
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
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
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) Flowmap.gl contributors
|
|
3
|
+
* Copyright (c) 2018-2020 Teralytics
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
export { default as AnimatedFlowLinesLayer } from './AnimatedFlowLinesLayer';
|
|
7
|
+
export { default as FlowLinesLayer } from './FlowLinesLayer';
|
|
8
|
+
export { default as FlowCirclesLayer } from './FlowCirclesLayer';
|
|
9
|
+
export { default as FlowmapLayer } from './FlowmapLayer';
|
|
10
|
+
export * from './types';
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUVILE9BQU8sRUFBQyxPQUFPLElBQUksc0JBQXNCLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRSxPQUFPLEVBQUMsT0FBTyxJQUFJLGNBQWMsRUFBQyxNQUFNLGtCQUFrQixDQUFDO0FBQzNELE9BQU8sRUFBQyxPQUFPLElBQUksZ0JBQWdCLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQztBQUMvRCxPQUFPLEVBQUMsT0FBTyxJQUFJLFlBQVksRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBR3ZELGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgRmxvd21hcC5nbCBjb250cmlidXRvcnNcbiAqIENvcHlyaWdodCAoYykgMjAxOC0yMDIwIFRlcmFseXRpY3NcbiAqIFNQRFgtTGljZW5zZS1JZGVudGlmaWVyOiBBcGFjaGUtMi4wXG4gKi9cblxuZXhwb3J0IHtkZWZhdWx0IGFzIEFuaW1hdGVkRmxvd0xpbmVzTGF5ZXJ9IGZyb20gJy4vQW5pbWF0ZWRGbG93TGluZXNMYXllcic7XG5leHBvcnQge2RlZmF1bHQgYXMgRmxvd0xpbmVzTGF5ZXJ9IGZyb20gJy4vRmxvd0xpbmVzTGF5ZXInO1xuZXhwb3J0IHtkZWZhdWx0IGFzIEZsb3dDaXJjbGVzTGF5ZXJ9IGZyb20gJy4vRmxvd0NpcmNsZXNMYXllcic7XG5leHBvcnQge2RlZmF1bHQgYXMgRmxvd21hcExheWVyfSBmcm9tICcuL0Zsb3dtYXBMYXllcic7XG5leHBvcnQgdHlwZSB7Rmxvd21hcExheWVyUHJvcHN9IGZyb20gJy4vRmxvd21hcExheWVyJztcblxuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG4iXX0=
|