1 | var __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 | })();
|
14 | var __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 | };
|
25 | var __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 | };
|
32 | import React from "react";
|
33 | import { Animated, ScrollView, StyleSheet, TextInput, View } from "react-native";
|
34 | import { Circle, G, Path, Polygon, Polyline, Rect, Svg } from "react-native-svg";
|
35 | import AbstractChart from "../AbstractChart";
|
36 | import { LegendItem } from "./LegendItem";
|
37 | var AnimatedCircle = Animated.createAnimatedComponent(Circle);
|
38 | var LineChart = (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));
|
438 | export 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 |