UNPKG

88.1 kBJavaScriptView Raw
1var __extends = (this && this.__extends) || (function () {
2 var extendStatics = function (d, b) {
3 extendStatics = Object.setPrototypeOf ||
4 ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
5 function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
6 return extendStatics(d, b);
7 };
8 return function (d, b) {
9 extendStatics(d, b);
10 function __() { this.constructor = d; }
11 d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
12 };
13})();
14var __assign = (this && this.__assign) || function () {
15 __assign = Object.assign || function(t) {
16 for (var s, i = 1, n = arguments.length; i < n; i++) {
17 s = arguments[i];
18 for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
19 t[p] = s[p];
20 }
21 return t;
22 };
23 return __assign.apply(this, arguments);
24};
25var __spreadArrays = (this && this.__spreadArrays) || function () {
26 for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
27 for (var r = Array(s), k = 0, i = 0; i < il; i++)
28 for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
29 r[k] = a[j];
30 return r;
31};
32import React from "react";
33import { Animated, ScrollView, StyleSheet, TextInput, View } from "react-native";
34import { Circle, G, Path, Polygon, Polyline, Rect, Svg } from "react-native-svg";
35import AbstractChart from "../AbstractChart";
36import { LegendItem } from "./LegendItem";
37var AnimatedCircle = Animated.createAnimatedComponent(Circle);
38var LineChart = /** @class */ (function (_super) {
39 __extends(LineChart, _super);
40 function LineChart() {
41 var _this = _super !== null && _super.apply(this, arguments) || this;
42 _this.label = React.createRef();
43 _this.state = {
44 scrollableDotHorizontalOffset: new Animated.Value(0)
45 };
46 _this.getColor = function (dataset, opacity) {
47 return (dataset.color || _this.props.chartConfig.color)(opacity);
48 };
49 _this.getStrokeWidth = function (dataset) {
50 return dataset.strokeWidth || _this.props.chartConfig.strokeWidth || 3;
51 };
52 _this.getDatas = function (data) {
53 return data.reduce(function (acc, item) { return (item.data ? __spreadArrays(acc, item.data) : acc); }, []);
54 };
55 _this.getPropsForDots = function (x, i) {
56 var _a = _this.props, getDotProps = _a.getDotProps, chartConfig = _a.chartConfig;
57 if (typeof getDotProps === "function") {
58 return getDotProps(x, i);
59 }
60 var _b = chartConfig.propsForDots, propsForDots = _b === void 0 ? {} : _b;
61 return __assign({ r: "4" }, propsForDots);
62 };
63 _this.renderDots = function (_a) {
64 var data = _a.data, width = _a.width, height = _a.height, paddingTop = _a.paddingTop, paddingRight = _a.paddingRight, onDataPointClick = _a.onDataPointClick;
65 var output = [];
66 var datas = _this.getDatas(data);
67 var baseHeight = _this.calcBaseHeight(datas, height);
68 var _b = _this.props, getDotColor = _b.getDotColor, _c = _b.hidePointsAtIndex, hidePointsAtIndex = _c === void 0 ? [] : _c, _d = _b.renderDotContent, renderDotContent = _d === void 0 ? function () {
69 return null;
70 } : _d;
71 data.forEach(function (dataset) {
72 if (dataset.withDots == false)
73 return;
74 dataset.data.forEach(function (x, i) {
75 if (hidePointsAtIndex.includes(i)) {
76 return;
77 }
78 var cx = paddingRight + (i * (width - paddingRight)) / dataset.data.length;
79 var cy = ((baseHeight - _this.calcHeight(x, datas, height)) / 4) * 3 +
80 paddingTop;
81 var onPress = function () {
82 if (!onDataPointClick || hidePointsAtIndex.includes(i)) {
83 return;
84 }
85 onDataPointClick({
86 index: i,
87 value: x,
88 dataset: dataset,
89 x: cx,
90 y: cy,
91 getColor: function (opacity) { return _this.getColor(dataset, opacity); }
92 });
93 };
94 output.push(<Circle key={Math.random()} cx={cx} cy={cy} fill={typeof getDotColor === "function"
95 ? getDotColor(x, i)
96 : _this.getColor(dataset, 0.9)} onPress={onPress} {..._this.getPropsForDots(x, i)}/>, <Circle key={Math.random()} cx={cx} cy={cy} r="14" fill="#fff" fillOpacity={0} onPress={onPress}/>, renderDotContent({ x: cx, y: cy, index: i }));
97 });
98 });
99 return output;
100 };
101 _this.renderScrollableDot = function (_a) {
102 var data = _a.data, width = _a.width, height = _a.height, paddingTop = _a.paddingTop, paddingRight = _a.paddingRight, scrollableDotHorizontalOffset = _a.scrollableDotHorizontalOffset, scrollableDotFill = _a.scrollableDotFill, scrollableDotStrokeColor = _a.scrollableDotStrokeColor, scrollableDotStrokeWidth = _a.scrollableDotStrokeWidth, scrollableDotRadius = _a.scrollableDotRadius, scrollableInfoViewStyle = _a.scrollableInfoViewStyle, scrollableInfoTextStyle = _a.scrollableInfoTextStyle, _b = _a.scrollableInfoTextDecorator, scrollableInfoTextDecorator = _b === void 0 ? function (x) { return "" + x; } : _b, scrollableInfoSize = _a.scrollableInfoSize, scrollableInfoOffset = _a.scrollableInfoOffset;
103 var output = [];
104 var datas = _this.getDatas(data);
105 var baseHeight = _this.calcBaseHeight(datas, height);
106 var vl = [];
107 var perData = width / data[0].data.length;
108 for (var index = 0; index < data[0].data.length; index++) {
109 vl.push(index * perData);
110 }
111 var lastIndex;
112 scrollableDotHorizontalOffset.addListener(function (value) {
113 var index = value.value / perData;
114 if (!lastIndex) {
115 lastIndex = index;
116 }
117 var abs = Math.floor(index);
118 var percent = index - abs;
119 abs = data[0].data.length - abs - 1;
120 if (index >= data[0].data.length - 1) {
121 _this.label.current.setNativeProps({
122 text: scrollableInfoTextDecorator(Math.floor(data[0].data[0]))
123 });
124 }
125 else {
126 if (index > lastIndex) {
127 // to right
128 var base = data[0].data[abs];
129 var prev = data[0].data[abs - 1];
130 if (prev > base) {
131 var rest = prev - base;
132 _this.label.current.setNativeProps({
133 text: scrollableInfoTextDecorator(Math.floor(base + percent * rest))
134 });
135 }
136 else {
137 var rest = base - prev;
138 _this.label.current.setNativeProps({
139 text: scrollableInfoTextDecorator(Math.floor(base - percent * rest))
140 });
141 }
142 }
143 else {
144 // to left
145 var base = data[0].data[abs - 1];
146 var next = data[0].data[abs];
147 percent = 1 - percent;
148 if (next > base) {
149 var rest = next - base;
150 _this.label.current.setNativeProps({
151 text: scrollableInfoTextDecorator(Math.floor(base + percent * rest))
152 });
153 }
154 else {
155 var rest = base - next;
156 _this.label.current.setNativeProps({
157 text: scrollableInfoTextDecorator(Math.floor(base - percent * rest))
158 });
159 }
160 }
161 }
162 lastIndex = index;
163 });
164 data.forEach(function (dataset) {
165 if (dataset.withScrollableDot == false)
166 return;
167 var perData = width / dataset.data.length;
168 var values = [];
169 var yValues = [];
170 var xValues = [];
171 var yValuesLabel = [];
172 var xValuesLabel = [];
173 for (var index = 0; index < dataset.data.length; index++) {
174 values.push(index * perData);
175 var yval = ((baseHeight -
176 _this.calcHeight(dataset.data[dataset.data.length - index - 1], datas, height)) /
177 4) *
178 3 +
179 paddingTop;
180 yValues.push(yval);
181 var xval = paddingRight +
182 ((dataset.data.length - index - 1) * (width - paddingRight)) /
183 dataset.data.length;
184 xValues.push(xval);
185 yValuesLabel.push(yval - (scrollableInfoSize.height + scrollableInfoOffset));
186 xValuesLabel.push(xval - scrollableInfoSize.width / 2);
187 }
188 var translateX = scrollableDotHorizontalOffset.interpolate({
189 inputRange: values,
190 outputRange: xValues,
191 extrapolate: "clamp"
192 });
193 var translateY = scrollableDotHorizontalOffset.interpolate({
194 inputRange: values,
195 outputRange: yValues,
196 extrapolate: "clamp"
197 });
198 var labelTranslateX = scrollableDotHorizontalOffset.interpolate({
199 inputRange: values,
200 outputRange: xValuesLabel,
201 extrapolate: "clamp"
202 });
203 var labelTranslateY = scrollableDotHorizontalOffset.interpolate({
204 inputRange: values,
205 outputRange: yValuesLabel,
206 extrapolate: "clamp"
207 });
208 output.push([
209 <Animated.View key={Math.random()} style={[
210 scrollableInfoViewStyle,
211 {
212 transform: [
213 { translateX: labelTranslateX },
214 { translateY: labelTranslateY }
215 ],
216 width: scrollableInfoSize.width,
217 height: scrollableInfoSize.height
218 }
219 ]}>
220 <TextInput onLayout={function () {
221 _this.label.current.setNativeProps({
222 text: scrollableInfoTextDecorator(Math.floor(data[0].data[data[0].data.length - 1]))
223 });
224 }} style={scrollableInfoTextStyle} ref={_this.label}/>
225 </Animated.View>,
226 <AnimatedCircle key={Math.random()} cx={translateX} cy={translateY} r={scrollableDotRadius} stroke={scrollableDotStrokeColor} strokeWidth={scrollableDotStrokeWidth} fill={scrollableDotFill}/>
227 ]);
228 });
229 return output;
230 };
231 _this.renderShadow = function (_a) {
232 var width = _a.width, height = _a.height, paddingRight = _a.paddingRight, paddingTop = _a.paddingTop, data = _a.data, useColorFromDataset = _a.useColorFromDataset;
233 if (_this.props.bezier) {
234 return _this.renderBezierShadow({
235 width: width,
236 height: height,
237 paddingRight: paddingRight,
238 paddingTop: paddingTop,
239 data: data,
240 useColorFromDataset: useColorFromDataset
241 });
242 }
243 var datas = _this.getDatas(data);
244 var baseHeight = _this.calcBaseHeight(datas, height);
245 return data.map(function (dataset, index) {
246 return (<Polygon key={index} points={dataset.data
247 .map(function (d, i) {
248 var x = paddingRight +
249 (i * (width - paddingRight)) / dataset.data.length;
250 var y = ((baseHeight - _this.calcHeight(d, datas, height)) / 4) * 3 +
251 paddingTop;
252 return x + "," + y;
253 })
254 .join(" ") +
255 (" " + (paddingRight +
256 ((width - paddingRight) / dataset.data.length) *
257 (dataset.data.length - 1)) + "," + ((height / 4) * 3 +
258 paddingTop) + " " + paddingRight + "," + ((height / 4) * 3 + paddingTop))} fill={"url(#fillShadowGradient" + (useColorFromDataset ? "_" + index : "") + ")"} strokeWidth={0}/>);
259 });
260 };
261 _this.renderLine = function (_a) {
262 var width = _a.width, height = _a.height, paddingRight = _a.paddingRight, paddingTop = _a.paddingTop, data = _a.data, linejoinType = _a.linejoinType;
263 if (_this.props.bezier) {
264 return _this.renderBezierLine({
265 data: data,
266 width: width,
267 height: height,
268 paddingRight: paddingRight,
269 paddingTop: paddingTop
270 });
271 }
272 var output = [];
273 var datas = _this.getDatas(data);
274 var baseHeight = _this.calcBaseHeight(datas, height);
275 var lastPoint;
276 data.forEach(function (dataset, index) {
277 var points = dataset.data.map(function (d, i) {
278 if (d === null)
279 return lastPoint;
280 var x = (i * (width - paddingRight)) / dataset.data.length + paddingRight;
281 var y = ((baseHeight - _this.calcHeight(d, datas, height)) / 4) * 3 +
282 paddingTop;
283 lastPoint = x + "," + y;
284 return x + "," + y;
285 });
286 output.push(<Polyline key={index} strokeLinejoin={linejoinType} points={points.join(" ")} fill="none" stroke={_this.getColor(dataset, 0.2)} strokeWidth={_this.getStrokeWidth(dataset)}/>);
287 });
288 return output;
289 };
290 _this.getBezierLinePoints = function (dataset, _a) {
291 var width = _a.width, height = _a.height, paddingRight = _a.paddingRight, paddingTop = _a.paddingTop, data = _a.data;
292 if (dataset.data.length === 0) {
293 return "M0,0";
294 }
295 var datas = _this.getDatas(data);
296 var x = function (i) {
297 return Math.floor(paddingRight + (i * (width - paddingRight)) / dataset.data.length);
298 };
299 var baseHeight = _this.calcBaseHeight(datas, height);
300 var y = function (i) {
301 var yHeight = _this.calcHeight(dataset.data[i], datas, height);
302 return Math.floor(((baseHeight - yHeight) / 4) * 3 + paddingTop);
303 };
304 return ["M" + x(0) + "," + y(0)]
305 .concat(dataset.data.slice(0, -1).map(function (_, i) {
306 var x_mid = (x(i) + x(i + 1)) / 2;
307 var y_mid = (y(i) + y(i + 1)) / 2;
308 var cp_x1 = (x_mid + x(i)) / 2;
309 var cp_x2 = (x_mid + x(i + 1)) / 2;
310 return ("Q " + cp_x1 + ", " + y(i) + ", " + x_mid + ", " + y_mid +
311 (" Q " + cp_x2 + ", " + y(i + 1) + ", " + x(i + 1) + ", " + y(i + 1)));
312 }))
313 .join(" ");
314 };
315 _this.renderBezierLine = function (_a) {
316 var data = _a.data, width = _a.width, height = _a.height, paddingRight = _a.paddingRight, paddingTop = _a.paddingTop;
317 return data.map(function (dataset, index) {
318 var result = _this.getBezierLinePoints(dataset, {
319 width: width,
320 height: height,
321 paddingRight: paddingRight,
322 paddingTop: paddingTop,
323 data: data
324 });
325 return (<Path key={index} d={result} fill="none" stroke={_this.getColor(dataset, 0.2)} strokeWidth={_this.getStrokeWidth(dataset)}/>);
326 });
327 };
328 _this.renderBezierShadow = function (_a) {
329 var width = _a.width, height = _a.height, paddingRight = _a.paddingRight, paddingTop = _a.paddingTop, data = _a.data, useColorFromDataset = _a.useColorFromDataset;
330 return data.map(function (dataset, index) {
331 var d = _this.getBezierLinePoints(dataset, {
332 width: width,
333 height: height,
334 paddingRight: paddingRight,
335 paddingTop: paddingTop,
336 data: data
337 }) +
338 (" L" + (paddingRight +
339 ((width - paddingRight) / dataset.data.length) *
340 (dataset.data.length - 1)) + "," + ((height / 4) * 3 +
341 paddingTop) + " L" + paddingRight + "," + ((height / 4) * 3 + paddingTop) + " Z");
342 return (<Path key={index} d={d} fill={"url(#fillShadowGradient" + (useColorFromDataset ? "_" + index : "") + ")"} strokeWidth={0}/>);
343 });
344 };
345 _this.renderLegend = function (width, legendOffset) {
346 var _a = _this.props.data, legend = _a.legend, datasets = _a.datasets;
347 var baseLegendItemX = width / (legend.length + 1);
348 return legend.map(function (legendItem, i) { return (<G key={Math.random()}>
349 <LegendItem index={i} iconColor={_this.getColor(datasets[i], 0.9)} baseLegendItemX={baseLegendItemX} legendText={legendItem} labelProps={__assign({}, _this.getPropsForLabels())} legendOffset={legendOffset}/>
350 </G>); });
351 };
352 return _this;
353 }
354 LineChart.prototype.render = function () {
355 var _a = this.props, width = _a.width, height = _a.height, data = _a.data, _b = _a.withScrollableDot, withScrollableDot = _b === void 0 ? false : _b, _c = _a.withShadow, withShadow = _c === void 0 ? true : _c, _d = _a.withDots, withDots = _d === void 0 ? true : _d, _e = _a.withInnerLines, withInnerLines = _e === void 0 ? true : _e, _f = _a.withOuterLines, withOuterLines = _f === void 0 ? true : _f, _g = _a.withHorizontalLines, withHorizontalLines = _g === void 0 ? true : _g, _h = _a.withVerticalLines, withVerticalLines = _h === void 0 ? true : _h, _j = _a.withHorizontalLabels, withHorizontalLabels = _j === void 0 ? true : _j, _k = _a.withVerticalLabels, withVerticalLabels = _k === void 0 ? true : _k, _l = _a.style, style = _l === void 0 ? {} : _l, decorator = _a.decorator, onDataPointClick = _a.onDataPointClick, _m = _a.verticalLabelRotation, verticalLabelRotation = _m === void 0 ? 0 : _m, _o = _a.horizontalLabelRotation, horizontalLabelRotation = _o === void 0 ? 0 : _o, _p = _a.formatYLabel, formatYLabel = _p === void 0 ? function (yLabel) { return yLabel; } : _p, _q = _a.formatXLabel, formatXLabel = _q === void 0 ? function (xLabel) { return xLabel; } : _q, segments = _a.segments, _r = _a.transparent, transparent = _r === void 0 ? false : _r, chartConfig = _a.chartConfig;
356 var scrollableDotHorizontalOffset = this.state.scrollableDotHorizontalOffset;
357 var _s = data.labels, labels = _s === void 0 ? [] : _s;
358 var _t = style.borderRadius, borderRadius = _t === void 0 ? 0 : _t, _u = style.paddingTop, paddingTop = _u === void 0 ? 16 : _u, _v = style.paddingRight, paddingRight = _v === void 0 ? 64 : _v, _w = style.margin, margin = _w === void 0 ? 0 : _w, _x = style.marginRight, marginRight = _x === void 0 ? 0 : _x, _y = style.paddingBottom, paddingBottom = _y === void 0 ? 0 : _y;
359 var config = {
360 width: width,
361 height: height,
362 verticalLabelRotation: verticalLabelRotation,
363 horizontalLabelRotation: horizontalLabelRotation
364 };
365 var datas = this.getDatas(data.datasets);
366 var count = Math.min.apply(Math, datas) === Math.max.apply(Math, datas) ? 1 : 4;
367 if (segments) {
368 count = segments;
369 }
370 var legendOffset = this.props.data.legend ? height * 0.15 : 0;
371 return (<View style={style}>
372 <Svg height={height + paddingBottom + legendOffset} width={width - margin * 2 - marginRight}>
373 <Rect width="100%" height={height + legendOffset} rx={borderRadius} ry={borderRadius} fill="url(#backgroundGradient)" fillOpacity={transparent ? 0 : 1}/>
374 {this.props.data.legend &&
375 this.renderLegend(config.width, legendOffset)}
376 <G x="0" y={legendOffset}>
377 {this.renderDefs(__assign(__assign(__assign({}, config), chartConfig), { data: data.datasets }))}
378 <G>
379 {withHorizontalLines &&
380 (withInnerLines
381 ? this.renderHorizontalLines(__assign(__assign({}, config), { count: count, paddingTop: paddingTop,
382 paddingRight: paddingRight }))
383 : withOuterLines
384 ? this.renderHorizontalLine(__assign(__assign({}, config), { paddingTop: paddingTop,
385 paddingRight: paddingRight }))
386 : null)}
387 </G>
388 <G>
389 {withHorizontalLabels &&
390 this.renderHorizontalLabels(__assign(__assign({}, config), { count: count, data: datas, paddingTop: paddingTop, paddingRight: paddingRight, formatYLabel: formatYLabel, decimalPlaces: chartConfig.decimalPlaces }))}
391 </G>
392 <G>
393 {withVerticalLines &&
394 (withInnerLines
395 ? this.renderVerticalLines(__assign(__assign({}, config), { data: data.datasets[0].data, paddingTop: paddingTop, paddingRight: paddingRight }))
396 : withOuterLines
397 ? this.renderVerticalLine(__assign(__assign({}, config), { paddingTop: paddingTop, paddingRight: paddingRight }))
398 : null)}
399 </G>
400 <G>
401 {withVerticalLabels &&
402 this.renderVerticalLabels(__assign(__assign({}, config), { labels: labels, paddingTop: paddingTop, paddingRight: paddingRight, formatXLabel: formatXLabel }))}
403 </G>
404 <G>
405 {this.renderLine(__assign(__assign(__assign({}, config), chartConfig), { paddingRight: paddingRight, paddingTop: paddingTop, data: data.datasets }))}
406 </G>
407 <G>
408 {withShadow &&
409 this.renderShadow(__assign(__assign({}, config), { data: data.datasets, paddingRight: paddingRight, paddingTop: paddingTop, useColorFromDataset: chartConfig.useShadowColorFromDataset }))}
410 </G>
411 <G>
412 {withDots &&
413 this.renderDots(__assign(__assign({}, config), { data: data.datasets, paddingTop: paddingTop, paddingRight: paddingRight, onDataPointClick: onDataPointClick }))}
414 </G>
415 <G>
416 {withScrollableDot &&
417 this.renderScrollableDot(__assign(__assign(__assign({}, config), chartConfig), { data: data.datasets, paddingTop: paddingTop, paddingRight: paddingRight, onDataPointClick: onDataPointClick,
418 scrollableDotHorizontalOffset: scrollableDotHorizontalOffset }))}
419 </G>
420 <G>
421 {decorator &&
422 decorator(__assign(__assign({}, config), { data: data.datasets, paddingTop: paddingTop,
423 paddingRight: paddingRight }))}
424 </G>
425 </G>
426 </Svg>
427 {withScrollableDot && (<ScrollView style={StyleSheet.absoluteFill} contentContainerStyle={{ width: width * 2 }} showsHorizontalScrollIndicator={false} scrollEventThrottle={16} onScroll={Animated.event([
428 {
429 nativeEvent: {
430 contentOffset: { x: scrollableDotHorizontalOffset }
431 }
432 }
433 ])} horizontal bounces={false}/>)}
434 </View>);
435 };
436 return LineChart;
437}(AbstractChart));
438export default LineChart;
439//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"LineChart.js","sourceRoot":"","sources":["../../src/line-chart/LineChart.tsx"],"names":[],"mappings":"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","sourcesContent":["import React, { ReactNode } from \"react\";\nimport {\n  Animated,\n  ScrollView,\n  StyleSheet,\n  TextInput,\n  View,\n  ViewStyle\n} from \"react-native\";\nimport {\n  Circle,\n  G,\n  Path,\n  Polygon,\n  Polyline,\n  Rect,\n  Svg\n} from \"react-native-svg\";\n\nimport AbstractChart, {\n  AbstractChartConfig,\n  AbstractChartProps\n} from \"../AbstractChart\";\nimport { ChartData, Dataset } from \"../HelperTypes\";\nimport { LegendItem } from \"./LegendItem\";\n\nlet AnimatedCircle = Animated.createAnimatedComponent(Circle);\n\nexport interface LineChartData extends ChartData {\n  legend?: string[];\n}\n\nexport interface LineChartProps extends AbstractChartProps {\n  /**\n   * Data for the chart.\n   *\n   * Example from [docs](https://github.com/indiespirit/react-native-chart-kit#line-chart):\n   *\n   * ```javascript\n   * const data = {\n   *   labels: ['January', 'February', 'March', 'April', 'May', 'June'],\n   *   datasets: [{\n   *     data: [ 20, 45, 28, 80, 99, 43 ],\n   *     color: (opacity = 1) => `rgba(134, 65, 244, ${opacity})`, // optional\n   *     strokeWidth: 2 // optional\n   *   }],\n   *   legend: [\"Rainy Days\", \"Sunny Days\", \"Snowy Days\"] // optional\n   * }\n   * ```\n   */\n  data: LineChartData;\n  /**\n   * Width of the chart, use 'Dimensions' library to get the width of your screen for responsive.\n   */\n  width: number;\n  /**\n   * Height of the chart.\n   */\n  height: number;\n  /**\n   * Show dots on the line - default: True.\n   */\n  withDots?: boolean;\n  /**\n   * Show shadow for line - default: True.\n   */\n  withShadow?: boolean;\n  /**\n   * Show inner dashed lines - default: True.\n   */\n\n  withScrollableDot?: boolean;\n  withInnerLines?: boolean;\n  /**\n   * Show outer dashed lines - default: True.\n   */\n  withOuterLines?: boolean;\n  /**\n   * Show vertical lines - default: True.\n   */\n  withVerticalLines?: boolean;\n  /**\n   * Show horizontal lines - default: True.\n   */\n  withHorizontalLines?: boolean;\n  /**\n   * Show vertical labels - default: True.\n   */\n  withVerticalLabels?: boolean;\n  /**\n   * Show horizontal labels - default: True.\n   */\n  withHorizontalLabels?: boolean;\n  /**\n   * Render charts from 0 not from the minimum value. - default: False.\n   */\n  fromZero?: boolean;\n  /**\n   * Prepend text to horizontal labels -- default: ''.\n   */\n  yAxisLabel?: string;\n  /**\n   * Append text to horizontal labels -- default: ''.\n   */\n  yAxisSuffix?: string;\n  /**\n   * Prepend text to vertical labels -- default: ''.\n   */\n  xAxisLabel?: string;\n  /**\n   * Configuration object for the chart, see example:\n   *\n   * ```javascript\n   * const chartConfig = {\n   *   backgroundGradientFrom: \"#1E2923\",\n   *   backgroundGradientFromOpacity: 0,\n   *   backgroundGradientTo: \"#08130D\",\n   *   backgroundGradientToOpacity: 0.5,\n   *   color: (opacity = 1) => `rgba(26, 255, 146, ${opacity})`,\n   *   labelColor: (opacity = 1) => `rgba(26, 255, 146, ${opacity})`,\n   *   strokeWidth: 2, // optional, default 3\n   *   barPercentage: 0.5\n   * };\n   * ```\n   */\n  chartConfig?: AbstractChartConfig;\n\n  /**\n   * Divide axis quantity by the input number -- default: 1.\n   */\n  yAxisInterval?: number;\n\n  /**\n   * Defines if chart is transparent\n   */\n  transparent?: boolean;\n  /**\n   * This function takes a [whole bunch](https://github.com/indiespirit/react-native-chart-kit/blob/master/src/line-chart.js#L266)\n   * of stuff and can render extra elements,\n   * such as data point info or additional markup.\n   */\n  decorator?: Function;\n  /**\n   * Callback that is called when a data point is clicked.\n   */\n  onDataPointClick?: (data: {\n    index: number;\n    value: number;\n    dataset: Dataset;\n    x: number;\n    y: number;\n    getColor: (opacity: number) => string;\n  }) => void;\n  /**\n   * Style of the container view of the chart.\n   */\n  style?: Partial<ViewStyle>;\n  /**\n   * Add this prop to make the line chart smooth and curvy.\n   *\n   * [Example](https://github.com/indiespirit/react-native-chart-kit#bezier-line-chart)\n   */\n  bezier?: boolean;\n  /**\n   * Defines the dot color function that is used to calculate colors of dots in a line chart.\n   * Takes `(dataPoint, dataPointIndex)` as arguments.\n   */\n  getDotColor?: (dataPoint: any, index: number) => string;\n  /**\n   * Renders additional content for dots in a line chart.\n   * Takes `({x, y, index})` as arguments.\n   */\n  renderDotContent?: (params: {\n    x: number;\n    y: number;\n    index: number;\n  }) => React.ReactNode;\n  /**\n   * Rotation angle of the horizontal labels - default 0 (degrees).\n   */\n  horizontalLabelRotation?: number;\n  /**\n   * Rotation angle of the vertical labels - default 0 (degrees).\n   */\n  verticalLabelRotation?: number;\n  /**\n   * Offset for Y axis labels.\n   */\n  yLabelsOffset?: number;\n  /**\n   * Offset for X axis labels.\n   */\n  xLabelsOffset?: number;\n  /**\n   * Array of indices of the data points you don't want to display.\n   */\n  hidePointsAtIndex?: number[];\n  /**\n   * This function change the format of the display value of the Y label.\n   * Takes the y value as argument and should return the desirable string.\n   */\n  formatYLabel?: (yValue: string) => string;\n  /**\n   * This function change the format of the display value of the X label.\n   * Takes the X value as argument and should return the desirable string.\n   */\n  formatXLabel?: (xValue: string) => string;\n  /**\n   * Provide props for a data point dot.\n   */\n  getDotProps?: (dataPoint: any, index: number) => object;\n  /**\n   * The number of horizontal lines\n   */\n  segments?: number;\n}\n\ntype LineChartState = {\n  scrollableDotHorizontalOffset: Animated.Value;\n};\n\nclass LineChart extends AbstractChart<LineChartProps, LineChartState> {\n  label = React.createRef<TextInput>();\n\n  state = {\n    scrollableDotHorizontalOffset: new Animated.Value(0)\n  };\n\n  getColor = (dataset: Dataset, opacity: number) => {\n    return (dataset.color || this.props.chartConfig.color)(opacity);\n  };\n\n  getStrokeWidth = (dataset: Dataset) => {\n    return dataset.strokeWidth || this.props.chartConfig.strokeWidth || 3;\n  };\n\n  getDatas = (data: Dataset[]): number[] => {\n    return data.reduce(\n      (acc, item) => (item.data ? [...acc, ...item.data] : acc),\n      []\n    );\n  };\n\n  getPropsForDots = (x: any, i: number) => {\n    const { getDotProps, chartConfig } = this.props;\n\n    if (typeof getDotProps === \"function\") {\n      return getDotProps(x, i);\n    }\n\n    const { propsForDots = {} } = chartConfig;\n\n    return { r: \"4\", ...propsForDots };\n  };\n\n  renderDots = ({\n    data,\n    width,\n    height,\n    paddingTop,\n    paddingRight,\n    onDataPointClick\n  }: Pick<\n    AbstractChartConfig,\n    \"data\" | \"width\" | \"height\" | \"paddingRight\" | \"paddingTop\"\n  > & {\n    onDataPointClick: LineChartProps[\"onDataPointClick\"];\n  }) => {\n    const output: ReactNode[] = [];\n    const datas = this.getDatas(data);\n    const baseHeight = this.calcBaseHeight(datas, height);\n\n    const {\n      getDotColor,\n      hidePointsAtIndex = [],\n      renderDotContent = () => {\n        return null;\n      }\n    } = this.props;\n\n    data.forEach(dataset => {\n      if (dataset.withDots == false) return;\n\n      dataset.data.forEach((x, i) => {\n        if (hidePointsAtIndex.includes(i)) {\n          return;\n        }\n\n        const cx =\n          paddingRight + (i * (width - paddingRight)) / dataset.data.length;\n\n        const cy =\n          ((baseHeight - this.calcHeight(x, datas, height)) / 4) * 3 +\n          paddingTop;\n\n        const onPress = () => {\n          if (!onDataPointClick || hidePointsAtIndex.includes(i)) {\n            return;\n          }\n\n          onDataPointClick({\n            index: i,\n            value: x,\n            dataset,\n            x: cx,\n            y: cy,\n            getColor: opacity => this.getColor(dataset, opacity)\n          });\n        };\n\n        output.push(\n          <Circle\n            key={Math.random()}\n            cx={cx}\n            cy={cy}\n            fill={\n              typeof getDotColor === \"function\"\n                ? getDotColor(x, i)\n                : this.getColor(dataset, 0.9)\n            }\n            onPress={onPress}\n            {...this.getPropsForDots(x, i)}\n          />,\n          <Circle\n            key={Math.random()}\n            cx={cx}\n            cy={cy}\n            r=\"14\"\n            fill=\"#fff\"\n            fillOpacity={0}\n            onPress={onPress}\n          />,\n          renderDotContent({ x: cx, y: cy, index: i })\n        );\n      });\n    });\n\n    return output;\n  };\n\n  renderScrollableDot = ({\n    data,\n    width,\n    height,\n    paddingTop,\n    paddingRight,\n    scrollableDotHorizontalOffset,\n    scrollableDotFill,\n    scrollableDotStrokeColor,\n    scrollableDotStrokeWidth,\n    scrollableDotRadius,\n    scrollableInfoViewStyle,\n    scrollableInfoTextStyle,\n    scrollableInfoTextDecorator = x => `${x}`,\n    scrollableInfoSize,\n    scrollableInfoOffset\n  }: AbstractChartConfig & {\n    onDataPointClick: LineChartProps[\"onDataPointClick\"];\n    scrollableDotHorizontalOffset: Animated.Value;\n  }) => {\n    const output = [];\n    const datas = this.getDatas(data);\n    const baseHeight = this.calcBaseHeight(datas, height);\n\n    let vl: number[] = [];\n\n    const perData = width / data[0].data.length;\n    for (let index = 0; index < data[0].data.length; index++) {\n      vl.push(index * perData);\n    }\n    let lastIndex: number;\n\n    scrollableDotHorizontalOffset.addListener(value => {\n      const index = value.value / perData;\n      if (!lastIndex) {\n        lastIndex = index;\n      }\n\n      let abs = Math.floor(index);\n      let percent = index - abs;\n      abs = data[0].data.length - abs - 1;\n\n      if (index >= data[0].data.length - 1) {\n        this.label.current.setNativeProps({\n          text: scrollableInfoTextDecorator(Math.floor(data[0].data[0]))\n        });\n      } else {\n        if (index > lastIndex) {\n          // to right\n\n          const base = data[0].data[abs];\n          const prev = data[0].data[abs - 1];\n          if (prev > base) {\n            let rest = prev - base;\n            this.label.current.setNativeProps({\n              text: scrollableInfoTextDecorator(\n                Math.floor(base + percent * rest)\n              )\n            });\n          } else {\n            let rest = base - prev;\n            this.label.current.setNativeProps({\n              text: scrollableInfoTextDecorator(\n                Math.floor(base - percent * rest)\n              )\n            });\n          }\n        } else {\n          // to left\n\n          const base = data[0].data[abs - 1];\n          const next = data[0].data[abs];\n          percent = 1 - percent;\n          if (next > base) {\n            let rest = next - base;\n            this.label.current.setNativeProps({\n              text: scrollableInfoTextDecorator(\n                Math.floor(base + percent * rest)\n              )\n            });\n          } else {\n            let rest = base - next;\n            this.label.current.setNativeProps({\n              text: scrollableInfoTextDecorator(\n                Math.floor(base - percent * rest)\n              )\n            });\n          }\n        }\n      }\n      lastIndex = index;\n    });\n\n    data.forEach(dataset => {\n      if (dataset.withScrollableDot == false) return;\n\n      const perData = width / dataset.data.length;\n      let values = [];\n      let yValues = [];\n      let xValues = [];\n\n      let yValuesLabel = [];\n      let xValuesLabel = [];\n\n      for (let index = 0; index < dataset.data.length; index++) {\n        values.push(index * perData);\n        const yval =\n          ((baseHeight -\n            this.calcHeight(\n              dataset.data[dataset.data.length - index - 1],\n              datas,\n              height\n            )) /\n            4) *\n            3 +\n          paddingTop;\n        yValues.push(yval);\n        const xval =\n          paddingRight +\n          ((dataset.data.length - index - 1) * (width - paddingRight)) /\n            dataset.data.length;\n        xValues.push(xval);\n\n        yValuesLabel.push(\n          yval - (scrollableInfoSize.height + scrollableInfoOffset)\n        );\n        xValuesLabel.push(xval - scrollableInfoSize.width / 2);\n      }\n\n      const translateX = scrollableDotHorizontalOffset.interpolate({\n        inputRange: values,\n        outputRange: xValues,\n        extrapolate: \"clamp\"\n      });\n\n      const translateY = scrollableDotHorizontalOffset.interpolate({\n        inputRange: values,\n        outputRange: yValues,\n        extrapolate: \"clamp\"\n      });\n\n      const labelTranslateX = scrollableDotHorizontalOffset.interpolate({\n        inputRange: values,\n        outputRange: xValuesLabel,\n        extrapolate: \"clamp\"\n      });\n\n      const labelTranslateY = scrollableDotHorizontalOffset.interpolate({\n        inputRange: values,\n        outputRange: yValuesLabel,\n        extrapolate: \"clamp\"\n      });\n\n      output.push([\n        <Animated.View\n          key={Math.random()}\n          style={[\n            scrollableInfoViewStyle,\n            {\n              transform: [\n                { translateX: labelTranslateX },\n                { translateY: labelTranslateY }\n              ],\n              width: scrollableInfoSize.width,\n              height: scrollableInfoSize.height\n            }\n          ]}\n        >\n          <TextInput\n            onLayout={() => {\n              this.label.current.setNativeProps({\n                text: scrollableInfoTextDecorator(\n                  Math.floor(data[0].data[data[0].data.length - 1])\n                )\n              });\n            }}\n            style={scrollableInfoTextStyle}\n            ref={this.label}\n          />\n        </Animated.View>,\n        <AnimatedCircle\n          key={Math.random()}\n          cx={translateX}\n          cy={translateY}\n          r={scrollableDotRadius}\n          stroke={scrollableDotStrokeColor}\n          strokeWidth={scrollableDotStrokeWidth}\n          fill={scrollableDotFill}\n        />\n      ]);\n    });\n\n    return output;\n  };\n\n  renderShadow = ({\n    width,\n    height,\n    paddingRight,\n    paddingTop,\n    data,\n    useColorFromDataset\n  }: Pick<\n    AbstractChartConfig,\n    \"data\" | \"width\" | \"height\" | \"paddingRight\" | \"paddingTop\"\n  > & {\n    useColorFromDataset: AbstractChartConfig[\"useShadowColorFromDataset\"];\n  }) => {\n    if (this.props.bezier) {\n      return this.renderBezierShadow({\n        width,\n        height,\n        paddingRight,\n        paddingTop,\n        data,\n        useColorFromDataset\n      });\n    }\n\n    const datas = this.getDatas(data);\n    const baseHeight = this.calcBaseHeight(datas, height);\n\n    return data.map((dataset, index) => {\n      return (\n        <Polygon\n          key={index}\n          points={\n            dataset.data\n              .map((d, i) => {\n                const x =\n                  paddingRight +\n                  (i * (width - paddingRight)) / dataset.data.length;\n\n                const y =\n                  ((baseHeight - this.calcHeight(d, datas, height)) / 4) * 3 +\n                  paddingTop;\n\n                return `${x},${y}`;\n              })\n              .join(\" \") +\n            ` ${paddingRight +\n              ((width - paddingRight) / dataset.data.length) *\n                (dataset.data.length - 1)},${(height / 4) * 3 +\n              paddingTop} ${paddingRight},${(height / 4) * 3 + paddingTop}`\n          }\n          fill={`url(#fillShadowGradient${\n            useColorFromDataset ? `_${index}` : \"\"\n          })`}\n          strokeWidth={0}\n        />\n      );\n    });\n  };\n\n  renderLine = ({\n    width,\n    height,\n    paddingRight,\n    paddingTop,\n    data,\n    linejoinType\n  }: Pick<\n    AbstractChartConfig,\n    \"data\" | \"width\" | \"height\" | \"paddingRight\" | \"paddingTop\" | \"linejoinType\"\n  >) => {\n    if (this.props.bezier) {\n      return this.renderBezierLine({\n        data,\n        width,\n        height,\n        paddingRight,\n        paddingTop\n      });\n    }\n\n    const output = [];\n    const datas = this.getDatas(data);\n    const baseHeight = this.calcBaseHeight(datas, height);\n\n    let lastPoint: string;\n\n    data.forEach((dataset, index) => {\n      const points = dataset.data.map((d, i) => {\n        if (d === null) return lastPoint;\n        const x =\n          (i * (width - paddingRight)) / dataset.data.length + paddingRight;\n        const y =\n          ((baseHeight - this.calcHeight(d, datas, height)) / 4) * 3 +\n          paddingTop;\n        lastPoint = `${x},${y}`;\n        return `${x},${y}`;\n      });\n\n      output.push(\n        <Polyline\n          key={index}\n          strokeLinejoin={linejoinType}\n          points={points.join(\" \")}\n          fill=\"none\"\n          stroke={this.getColor(dataset, 0.2)}\n          strokeWidth={this.getStrokeWidth(dataset)}\n        />\n      );\n    });\n\n    return output;\n  };\n\n  getBezierLinePoints = (\n    dataset: Dataset,\n    {\n      width,\n      height,\n      paddingRight,\n      paddingTop,\n      data\n    }: Pick<\n      AbstractChartConfig,\n      \"width\" | \"height\" | \"paddingRight\" | \"paddingTop\" | \"data\"\n    >\n  ) => {\n    if (dataset.data.length === 0) {\n      return \"M0,0\";\n    }\n\n    const datas = this.getDatas(data);\n\n    const x = (i: number) =>\n      Math.floor(\n        paddingRight + (i * (width - paddingRight)) / dataset.data.length\n      );\n\n    const baseHeight = this.calcBaseHeight(datas, height);\n\n    const y = (i: number) => {\n      const yHeight = this.calcHeight(dataset.data[i], datas, height);\n\n      return Math.floor(((baseHeight - yHeight) / 4) * 3 + paddingTop);\n    };\n\n    return [`M${x(0)},${y(0)}`]\n      .concat(\n        dataset.data.slice(0, -1).map((_, i) => {\n          const x_mid = (x(i) + x(i + 1)) / 2;\n          const y_mid = (y(i) + y(i + 1)) / 2;\n          const cp_x1 = (x_mid + x(i)) / 2;\n          const cp_x2 = (x_mid + x(i + 1)) / 2;\n          return (\n            `Q ${cp_x1}, ${y(i)}, ${x_mid}, ${y_mid}` +\n            ` Q ${cp_x2}, ${y(i + 1)}, ${x(i + 1)}, ${y(i + 1)}`\n          );\n        })\n      )\n      .join(\" \");\n  };\n\n  renderBezierLine = ({\n    data,\n    width,\n    height,\n    paddingRight,\n    paddingTop\n  }: Pick<\n    AbstractChartConfig,\n    \"data\" | \"width\" | \"height\" | \"paddingRight\" | \"paddingTop\"\n  >) => {\n    return data.map((dataset, index) => {\n      const result = this.getBezierLinePoints(dataset, {\n        width,\n        height,\n        paddingRight,\n        paddingTop,\n        data\n      });\n\n      return (\n        <Path\n          key={index}\n          d={result}\n          fill=\"none\"\n          stroke={this.getColor(dataset, 0.2)}\n          strokeWidth={this.getStrokeWidth(dataset)}\n        />\n      );\n    });\n  };\n\n  renderBezierShadow = ({\n    width,\n    height,\n    paddingRight,\n    paddingTop,\n    data,\n    useColorFromDataset\n  }: Pick<\n    AbstractChartConfig,\n    \"data\" | \"width\" | \"height\" | \"paddingRight\" | \"paddingTop\"\n  > & {\n    useColorFromDataset: AbstractChartConfig[\"useShadowColorFromDataset\"];\n  }) =>\n    data.map((dataset, index) => {\n      const d =\n        this.getBezierLinePoints(dataset, {\n          width,\n          height,\n          paddingRight,\n          paddingTop,\n          data\n        }) +\n        ` L${paddingRight +\n          ((width - paddingRight) / dataset.data.length) *\n            (dataset.data.length - 1)},${(height / 4) * 3 +\n          paddingTop} L${paddingRight},${(height / 4) * 3 + paddingTop} Z`;\n\n      return (\n        <Path\n          key={index}\n          d={d}\n          fill={`url(#fillShadowGradient${\n            useColorFromDataset ? `_${index}` : \"\"\n          })`}\n          strokeWidth={0}\n        />\n      );\n    });\n\n  renderLegend = (width, legendOffset) => {\n    const { legend, datasets } = this.props.data;\n    const baseLegendItemX = width / (legend.length + 1);\n\n    return legend.map((legendItem, i) => (\n      <G key={Math.random()}>\n        <LegendItem\n          index={i}\n          iconColor={this.getColor(datasets[i], 0.9)}\n          baseLegendItemX={baseLegendItemX}\n          legendText={legendItem}\n          labelProps={{ ...this.getPropsForLabels() }}\n          legendOffset={legendOffset}\n        />\n      </G>\n    ));\n  };\n\n  render() {\n    const {\n      width,\n      height,\n      data,\n      withScrollableDot = false,\n      withShadow = true,\n      withDots = true,\n      withInnerLines = true,\n      withOuterLines = true,\n      withHorizontalLines = true,\n      withVerticalLines = true,\n      withHorizontalLabels = true,\n      withVerticalLabels = true,\n      style = {},\n      decorator,\n      onDataPointClick,\n      verticalLabelRotation = 0,\n      horizontalLabelRotation = 0,\n      formatYLabel = yLabel => yLabel,\n      formatXLabel = xLabel => xLabel,\n      segments,\n      transparent = false,\n      chartConfig\n    } = this.props;\n\n    const { scrollableDotHorizontalOffset } = this.state;\n    const { labels = [] } = data;\n    const {\n      borderRadius = 0,\n      paddingTop = 16,\n      paddingRight = 64,\n      margin = 0,\n      marginRight = 0,\n      paddingBottom = 0\n    } = style;\n\n    const config = {\n      width,\n      height,\n      verticalLabelRotation,\n      horizontalLabelRotation\n    };\n\n    const datas = this.getDatas(data.datasets);\n\n    let count = Math.min(...datas) === Math.max(...datas) ? 1 : 4;\n    if (segments) {\n      count = segments;\n    }\n\n    const legendOffset = this.props.data.legend ? height * 0.15 : 0;\n\n    return (\n      <View style={style}>\n        <Svg\n          height={height + (paddingBottom as number) + legendOffset}\n          width={width - (margin as number) * 2 - (marginRight as number)}\n        >\n          <Rect\n            width=\"100%\"\n            height={height + legendOffset}\n            rx={borderRadius}\n            ry={borderRadius}\n            fill=\"url(#backgroundGradient)\"\n            fillOpacity={transparent ? 0 : 1}\n          />\n          {this.props.data.legend &&\n            this.renderLegend(config.width, legendOffset)}\n          <G x=\"0\" y={legendOffset}>\n            {this.renderDefs({\n              ...config,\n              ...chartConfig,\n              data: data.datasets\n            })}\n            <G>\n              {withHorizontalLines &&\n                (withInnerLines\n                  ? this.renderHorizontalLines({\n                      ...config,\n                      count: count,\n                      paddingTop,\n                      paddingRight\n                    })\n                  : withOuterLines\n                  ? this.renderHorizontalLine({\n                      ...config,\n                      paddingTop,\n                      paddingRight\n                    })\n                  : null)}\n            </G>\n            <G>\n              {withHorizontalLabels &&\n                this.renderHorizontalLabels({\n                  ...config,\n                  count: count,\n                  data: datas,\n                  paddingTop: paddingTop as number,\n                  paddingRight: paddingRight as number,\n                  formatYLabel,\n                  decimalPlaces: chartConfig.decimalPlaces\n                })}\n            </G>\n            <G>\n              {withVerticalLines &&\n                (withInnerLines\n                  ? this.renderVerticalLines({\n                      ...config,\n                      data: data.datasets[0].data,\n                      paddingTop: paddingTop as number,\n                      paddingRight: paddingRight as number\n                    })\n                  : withOuterLines\n                  ? this.renderVerticalLine({\n                      ...config,\n                      paddingTop: paddingTop as number,\n                      paddingRight: paddingRight as number\n                    })\n                  : null)}\n            </G>\n            <G>\n              {withVerticalLabels &&\n                this.renderVerticalLabels({\n                  ...config,\n                  labels,\n                  paddingTop: paddingTop as number,\n                  paddingRight: paddingRight as number,\n                  formatXLabel\n                })}\n            </G>\n            <G>\n              {this.renderLine({\n                ...config,\n                ...chartConfig,\n                paddingRight: paddingRight as number,\n                paddingTop: paddingTop as number,\n                data: data.datasets\n              })}\n            </G>\n            <G>\n              {withShadow &&\n                this.renderShadow({\n                  ...config,\n                  data: data.datasets,\n                  paddingRight: paddingRight as number,\n                  paddingTop: paddingTop as number,\n                  useColorFromDataset: chartConfig.useShadowColorFromDataset\n                })}\n            </G>\n            <G>\n              {withDots &&\n                this.renderDots({\n                  ...config,\n                  data: data.datasets,\n                  paddingTop: paddingTop as number,\n                  paddingRight: paddingRight as number,\n                  onDataPointClick\n                })}\n            </G>\n            <G>\n              {withScrollableDot &&\n                this.renderScrollableDot({\n                  ...config,\n                  ...chartConfig,\n                  data: data.datasets,\n                  paddingTop: paddingTop as number,\n                  paddingRight: paddingRight as number,\n                  onDataPointClick,\n                  scrollableDotHorizontalOffset\n                })}\n            </G>\n            <G>\n              {decorator &&\n                decorator({\n                  ...config,\n                  data: data.datasets,\n                  paddingTop,\n                  paddingRight\n                })}\n            </G>\n          </G>\n        </Svg>\n        {withScrollableDot && (\n          <ScrollView\n            style={StyleSheet.absoluteFill}\n            contentContainerStyle={{ width: width * 2 }}\n            showsHorizontalScrollIndicator={false}\n            scrollEventThrottle={16}\n            onScroll={Animated.event([\n              {\n                nativeEvent: {\n                  contentOffset: { x: scrollableDotHorizontalOffset }\n                }\n              }\n            ])}\n            horizontal\n            bounces={false}\n          />\n        )}\n      </View>\n    );\n  }\n}\n\nexport default LineChart;\n"]}
\No newline at end of file