@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.
Files changed (63) hide show
  1. package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayer.d.ts +76 -0
  2. package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayer.d.ts.map +1 -0
  3. package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayer.js +133 -0
  4. package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerFragment.glsl.d.ts +3 -0
  5. package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerFragment.glsl.d.ts.map +1 -0
  6. package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerFragment.glsl.js +25 -0
  7. package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerVertex.glsl.d.ts +3 -0
  8. package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerVertex.glsl.d.ts.map +1 -0
  9. package/dist/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerVertex.glsl.js +79 -0
  10. package/dist/AnimatedFlowLinesLayer/index.d.ts +3 -0
  11. package/dist/AnimatedFlowLinesLayer/index.d.ts.map +1 -0
  12. package/dist/AnimatedFlowLinesLayer/index.js +8 -0
  13. package/dist/FlowCirclesLayer/FlowCirclesLayer.d.ts +59 -0
  14. package/dist/FlowCirclesLayer/FlowCirclesLayer.d.ts.map +1 -0
  15. package/dist/FlowCirclesLayer/FlowCirclesLayer.js +106 -0
  16. package/dist/FlowCirclesLayer/FlowCirclesLayerFragment.glsl.d.ts +3 -0
  17. package/dist/FlowCirclesLayer/FlowCirclesLayerFragment.glsl.d.ts.map +1 -0
  18. package/dist/FlowCirclesLayer/FlowCirclesLayerFragment.glsl.js +65 -0
  19. package/dist/FlowCirclesLayer/FlowCirclesLayerVertex.glsl.d.ts +3 -0
  20. package/dist/FlowCirclesLayer/FlowCirclesLayerVertex.glsl.d.ts.map +1 -0
  21. package/dist/FlowCirclesLayer/FlowCirclesLayerVertex.glsl.js +51 -0
  22. package/dist/FlowCirclesLayer/index.d.ts +3 -0
  23. package/dist/FlowCirclesLayer/index.d.ts.map +1 -0
  24. package/dist/FlowCirclesLayer/index.js +8 -0
  25. package/dist/FlowLinesLayer/FlowLinesLayer.d.ts +64 -0
  26. package/dist/FlowLinesLayer/FlowLinesLayer.d.ts.map +1 -0
  27. package/dist/FlowLinesLayer/FlowLinesLayer.js +188 -0
  28. package/dist/FlowLinesLayer/FlowLinesLayerFragment.glsl.d.ts +3 -0
  29. package/dist/FlowLinesLayer/FlowLinesLayerFragment.glsl.d.ts.map +1 -0
  30. package/dist/FlowLinesLayer/FlowLinesLayerFragment.glsl.js +24 -0
  31. package/dist/FlowLinesLayer/FlowLinesLayerVertex.glsl.d.ts +3 -0
  32. package/dist/FlowLinesLayer/FlowLinesLayerVertex.glsl.d.ts.map +1 -0
  33. package/dist/FlowLinesLayer/FlowLinesLayerVertex.glsl.js +86 -0
  34. package/dist/FlowLinesLayer/index.d.ts +3 -0
  35. package/dist/FlowLinesLayer/index.d.ts.map +1 -0
  36. package/dist/FlowLinesLayer/index.js +8 -0
  37. package/dist/FlowmapLayer.d.ts +87 -0
  38. package/dist/FlowmapLayer.d.ts.map +1 -0
  39. package/dist/FlowmapLayer.js +434 -0
  40. package/dist/index.d.ts +7 -0
  41. package/dist/index.d.ts.map +1 -0
  42. package/dist/index.js +11 -0
  43. package/dist/types.d.ts +36 -0
  44. package/dist/types.d.ts.map +1 -0
  45. package/dist/types.js +25 -0
  46. package/package.json +29 -0
  47. package/src/AnimatedFlowLinesLayer/AnimatedFlowLinesLayer.ts +177 -0
  48. package/src/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerFragment.glsl.ts +25 -0
  49. package/src/AnimatedFlowLinesLayer/AnimatedFlowLinesLayerVertex.glsl.ts +78 -0
  50. package/src/AnimatedFlowLinesLayer/index.ts +9 -0
  51. package/src/FlowCirclesLayer/FlowCirclesLayer.ts +138 -0
  52. package/src/FlowCirclesLayer/FlowCirclesLayerFragment.glsl.ts +64 -0
  53. package/src/FlowCirclesLayer/FlowCirclesLayerVertex.glsl.ts +50 -0
  54. package/src/FlowCirclesLayer/index.ts +9 -0
  55. package/src/FlowLinesLayer/FlowLinesLayer.ts +232 -0
  56. package/src/FlowLinesLayer/FlowLinesLayerFragment.glsl.ts +23 -0
  57. package/src/FlowLinesLayer/FlowLinesLayerVertex.glsl.ts +85 -0
  58. package/src/FlowLinesLayer/index.ts +9 -0
  59. package/src/FlowmapLayer.ts +587 -0
  60. package/src/index.ts +13 -0
  61. package/src/types.ts +80 -0
  62. package/tsconfig.json +11 -0
  63. 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":"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"}
@@ -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"]}
@@ -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=