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 | import _ from "lodash";
|
26 | import React from "react";
|
27 | import { View } from "react-native";
|
28 | import { G, Rect, Svg, Text } from "react-native-svg";
|
29 | import AbstractChart from "../AbstractChart";
|
30 | import { mapValue } from "../Utils";
|
31 | import { convertToDate, getBeginningTimeForDate, shiftDate } from "./DateHelpers";
|
32 | import { DAYS_IN_WEEK, MILLISECONDS_IN_ONE_DAY, MONTH_LABELS } from "./constants";
|
33 | var SQUARE_SIZE = 20;
|
34 | var MONTH_LABEL_GUTTER_SIZE = 8;
|
35 | var paddingLeft = 32;
|
36 | var ContributionGraph = (function (_super) {
|
37 | __extends(ContributionGraph, _super);
|
38 | function ContributionGraph(props) {
|
39 | var _this = _super.call(this, props) || this;
|
40 | var _a = _this.getValueCache(props.values), maxValue = _a.maxValue, minValue = _a.minValue, valueCache = _a.valueCache;
|
41 | _this.state = {
|
42 | maxValue: maxValue,
|
43 | minValue: minValue,
|
44 | valueCache: valueCache
|
45 | };
|
46 | return _this;
|
47 | }
|
48 | ContributionGraph.prototype.UNSAFE_componentWillReceiveProps = function (nextProps) {
|
49 | var _a = this.getValueCache(nextProps.values), maxValue = _a.maxValue, minValue = _a.minValue, valueCache = _a.valueCache;
|
50 | this.setState({
|
51 | maxValue: maxValue,
|
52 | minValue: minValue,
|
53 | valueCache: valueCache
|
54 | });
|
55 | };
|
56 | ContributionGraph.prototype.getSquareSizeWithGutter = function () {
|
57 | return (this.props.squareSize || SQUARE_SIZE) + this.props.gutterSize;
|
58 | };
|
59 | ContributionGraph.prototype.getMonthLabelSize = function () {
|
60 | var _a = this.props.squareSize, squareSize = _a === void 0 ? SQUARE_SIZE : _a;
|
61 | if (!this.props.showMonthLabels) {
|
62 | return 0;
|
63 | }
|
64 | if (this.props.horizontal) {
|
65 | return squareSize + MONTH_LABEL_GUTTER_SIZE;
|
66 | }
|
67 | return 2 * (squareSize + MONTH_LABEL_GUTTER_SIZE);
|
68 | };
|
69 | ContributionGraph.prototype.getStartDate = function () {
|
70 | return shiftDate(this.getEndDate(), -this.props.numDays + 1);
|
71 | };
|
72 | ContributionGraph.prototype.getEndDate = function () {
|
73 | return getBeginningTimeForDate(convertToDate(this.props.endDate));
|
74 | };
|
75 | ContributionGraph.prototype.getStartDateWithEmptyDays = function () {
|
76 | return shiftDate(this.getStartDate(), -this.getNumEmptyDaysAtStart());
|
77 | };
|
78 | ContributionGraph.prototype.getNumEmptyDaysAtStart = function () {
|
79 | return this.getStartDate().getDay();
|
80 | };
|
81 | ContributionGraph.prototype.getNumEmptyDaysAtEnd = function () {
|
82 | return DAYS_IN_WEEK - 1 - this.getEndDate().getDay();
|
83 | };
|
84 | ContributionGraph.prototype.getWeekCount = function () {
|
85 | var numDaysRoundedToWeek = this.props.numDays +
|
86 | this.getNumEmptyDaysAtStart() +
|
87 | this.getNumEmptyDaysAtEnd();
|
88 | return Math.ceil(numDaysRoundedToWeek / DAYS_IN_WEEK);
|
89 | };
|
90 | ContributionGraph.prototype.getWeekWidth = function () {
|
91 | return DAYS_IN_WEEK * this.getSquareSizeWithGutter();
|
92 | };
|
93 | ContributionGraph.prototype.getWidth = function () {
|
94 | return (this.getWeekCount() * this.getSquareSizeWithGutter() -
|
95 | this.props.gutterSize);
|
96 | };
|
97 | ContributionGraph.prototype.getHeight = function () {
|
98 | return (this.getWeekWidth() + (this.getMonthLabelSize() - this.props.gutterSize));
|
99 | };
|
100 | ContributionGraph.prototype.getValueCache = function (values) {
|
101 | var _this = this;
|
102 | var minValue = Infinity, maxValue = -Infinity;
|
103 | return {
|
104 | valueCache: values.reduce(function (memo, value) {
|
105 | var date = convertToDate(value.date);
|
106 | var index = Math.floor((date.valueOf() - _this.getStartDateWithEmptyDays().valueOf()) /
|
107 | MILLISECONDS_IN_ONE_DAY);
|
108 | minValue = Math.min(value[_this.props.accessor], minValue);
|
109 | maxValue = Math.max(value[_this.props.accessor], maxValue);
|
110 | memo[index] = {
|
111 | value: value,
|
112 | title: _this.props.titleForValue
|
113 | ? _this.props.titleForValue(value)
|
114 | : null,
|
115 | tooltipDataAttrs: _this.getTooltipDataAttrsForValue(value)
|
116 | };
|
117 | return memo;
|
118 | }, {}),
|
119 | minValue: minValue,
|
120 | maxValue: maxValue
|
121 | };
|
122 | };
|
123 | ContributionGraph.prototype.getValueForIndex = function (index) {
|
124 | if (this.state.valueCache[index]) {
|
125 | return this.state.valueCache[index].value;
|
126 | }
|
127 | return null;
|
128 | };
|
129 | ContributionGraph.prototype.getClassNameForIndex = function (index) {
|
130 | if (this.state.valueCache[index]) {
|
131 | if (this.state.valueCache[index].value) {
|
132 | var count = this.state.valueCache[index].value[this.props.accessor];
|
133 | if (count) {
|
134 | var opacity = mapValue(count, this.state.minValue, this.state.maxValue, 0.15 + 0.05,
|
135 | 1);
|
136 | return this.props.chartConfig.color(opacity);
|
137 | }
|
138 | }
|
139 | }
|
140 | return this.props.chartConfig.color(0.15);
|
141 | };
|
142 | ContributionGraph.prototype.getTitleForIndex = function (index) {
|
143 | if (this.state.valueCache[index]) {
|
144 | return this.state.valueCache[index].title;
|
145 | }
|
146 | return this.props.titleForValue ? this.props.titleForValue(null) : null;
|
147 | };
|
148 | ContributionGraph.prototype.getTooltipDataAttrsForIndex = function (index) {
|
149 | var _a;
|
150 | if (this.state.valueCache[index]) {
|
151 | return this.state.valueCache[index].tooltipDataAttrs;
|
152 | }
|
153 | return this.getTooltipDataAttrsForValue((_a = {
|
154 | date: null
|
155 | },
|
156 | _a[this.props.accessor] = null,
|
157 | _a));
|
158 | };
|
159 | ContributionGraph.prototype.getTooltipDataAttrsForValue = function (value) {
|
160 | var tooltipDataAttrs = this.props.tooltipDataAttrs;
|
161 | if (typeof tooltipDataAttrs === "function") {
|
162 | return tooltipDataAttrs(value);
|
163 | }
|
164 | return tooltipDataAttrs;
|
165 | };
|
166 | ContributionGraph.prototype.getTransformForWeek = function (weekIndex) {
|
167 | if (this.props.horizontal) {
|
168 | return [weekIndex * this.getSquareSizeWithGutter(), 50];
|
169 | }
|
170 | return [10, weekIndex * this.getSquareSizeWithGutter()];
|
171 | };
|
172 | ContributionGraph.prototype.getTransformForMonthLabels = function () {
|
173 | if (this.props.horizontal) {
|
174 | return null;
|
175 | }
|
176 | return this.getWeekWidth() + MONTH_LABEL_GUTTER_SIZE + ", 0";
|
177 | };
|
178 | ContributionGraph.prototype.getTransformForAllWeeks = function () {
|
179 | if (this.props.horizontal) {
|
180 | return "0, " + (this.getMonthLabelSize() - 100);
|
181 | }
|
182 | return null;
|
183 | };
|
184 | ContributionGraph.prototype.getViewBox = function () {
|
185 | if (this.props.horizontal) {
|
186 | return this.getWidth() + " " + this.getHeight();
|
187 | }
|
188 | return this.getHeight() + " " + this.getWidth();
|
189 | };
|
190 | ContributionGraph.prototype.getSquareCoordinates = function (dayIndex) {
|
191 | if (this.props.horizontal) {
|
192 | return [0, dayIndex * this.getSquareSizeWithGutter()];
|
193 | }
|
194 | return [dayIndex * this.getSquareSizeWithGutter(), 0];
|
195 | };
|
196 | ContributionGraph.prototype.getMonthLabelCoordinates = function (weekIndex) {
|
197 | if (this.props.horizontal) {
|
198 | return [
|
199 | weekIndex * this.getSquareSizeWithGutter(),
|
200 | this.getMonthLabelSize() - MONTH_LABEL_GUTTER_SIZE
|
201 | ];
|
202 | }
|
203 | var verticalOffset = -2;
|
204 | return [
|
205 | 0,
|
206 | (weekIndex + 1) * this.getSquareSizeWithGutter() + verticalOffset
|
207 | ];
|
208 | };
|
209 | ContributionGraph.prototype.renderSquare = function (dayIndex, index) {
|
210 | var _this = this;
|
211 | var indexOutOfRange = index < this.getNumEmptyDaysAtStart() ||
|
212 | index >= this.getNumEmptyDaysAtStart() + this.props.numDays;
|
213 | if (indexOutOfRange && !this.props.showOutOfRangeDays) {
|
214 | return null;
|
215 | }
|
216 | var _a = this.getSquareCoordinates(dayIndex), x = _a[0], y = _a[1];
|
217 | var _b = this.props.squareSize, squareSize = _b === void 0 ? SQUARE_SIZE : _b;
|
218 | return (<Rect key={index} width={squareSize} height={squareSize} x={x + paddingLeft} y={y} title={this.getTitleForIndex(index)} fill={this.getClassNameForIndex(index)} onPress={function () {
|
219 | _this.handleDayPress(index);
|
220 | }} {...this.getTooltipDataAttrsForIndex(index)}/>);
|
221 | };
|
222 | ContributionGraph.prototype.handleDayPress = function (index) {
|
223 | var _a;
|
224 | if (!this.props.onDayPress) {
|
225 | return;
|
226 | }
|
227 | this.props.onDayPress(this.state.valueCache[index] && this.state.valueCache[index].value
|
228 | ? this.state.valueCache[index].value
|
229 | : (_a = {},
|
230 | _a[this.props.accessor] = 0,
|
231 | _a.date = new Date(this.getStartDate().valueOf() + index * MILLISECONDS_IN_ONE_DAY),
|
232 | _a));
|
233 | };
|
234 | ContributionGraph.prototype.renderWeek = function (weekIndex) {
|
235 | var _this = this;
|
236 | var _a = this.getTransformForWeek(weekIndex), x = _a[0], y = _a[1];
|
237 | return (<G key={weekIndex} x={x} y={y}>
|
238 | {_.range(DAYS_IN_WEEK).map(function (dayIndex) {
|
239 | return _this.renderSquare(dayIndex, weekIndex * DAYS_IN_WEEK + dayIndex);
|
240 | })}
|
241 | </G>);
|
242 | };
|
243 | ContributionGraph.prototype.renderAllWeeks = function () {
|
244 | var _this = this;
|
245 | return _.range(this.getWeekCount()).map(function (weekIndex) {
|
246 | return _this.renderWeek(weekIndex);
|
247 | });
|
248 | };
|
249 | ContributionGraph.prototype.renderMonthLabels = function () {
|
250 | var _this = this;
|
251 | if (!this.props.showMonthLabels) {
|
252 | return null;
|
253 | }
|
254 | var weekRange = _.range(this.getWeekCount() - 1); // don't render for last week, because label will be cut off
|
255 | return weekRange.map(function (weekIndex) {
|
256 | var endOfWeek = shiftDate(_this.getStartDateWithEmptyDays(), (weekIndex + 1) * DAYS_IN_WEEK);
|
257 | var _a = _this.getMonthLabelCoordinates(weekIndex), x = _a[0], y = _a[1];
|
258 | return endOfWeek.getDate() >= 1 && endOfWeek.getDate() <= DAYS_IN_WEEK ? (<Text key={weekIndex} x={x + paddingLeft} y={y + 8} {..._this.getPropsForLabels()}>
|
259 | {_this.props.getMonthLabel
|
260 | ? _this.props.getMonthLabel(endOfWeek.getMonth())
|
261 | : MONTH_LABELS[endOfWeek.getMonth()]}
|
262 | </Text>) : null;
|
263 | });
|
264 | };
|
265 | ContributionGraph.prototype.render = function () {
|
266 | var style = this.props.style;
|
267 | var _a = style.borderRadius, borderRadius = _a === void 0 ? 0 : _a;
|
268 | if (!borderRadius && this.props.chartConfig.style) {
|
269 | var stupidXo = this.props.chartConfig.style.borderRadius;
|
270 | borderRadius = stupidXo;
|
271 | }
|
272 | return (<View style={style}>
|
273 | <Svg height={this.props.height} width={this.props.width}>
|
274 | {this.renderDefs(__assign({ width: this.props.width, height: this.props.height }, this.props.chartConfig))}
|
275 | <Rect width="100%" height={this.props.height} rx={borderRadius} ry={borderRadius} fill="url(#backgroundGradient)"/>
|
276 | <G>{this.renderMonthLabels()}</G>
|
277 | <G>{this.renderAllWeeks()}</G>
|
278 | </Svg>
|
279 | </View>);
|
280 | };
|
281 | ContributionGraph.defaultProps = {
|
282 | numDays: 200,
|
283 | endDate: new Date(),
|
284 | gutterSize: 1,
|
285 | squareSize: SQUARE_SIZE,
|
286 | horizontal: true,
|
287 | showMonthLabels: true,
|
288 | showOutOfRangeDays: false,
|
289 | accessor: "count",
|
290 | classForValue: function (value) { return (value ? "black" : "#8cc665"); },
|
291 | style: {}
|
292 | };
|
293 | return ContributionGraph;
|
294 | }(AbstractChart));
|
295 | export default ContributionGraph;
|
296 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ContributionGraph.js","sourceRoot":"","sources":["../../src/contribution-graph/ContributionGraph.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,CAAC,MAAM,QAAQ,CAAC;AACvB,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AACpC,OAAO,EAAE,CAAC,EAAE,IAAI,EAAa,GAAG,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAEjE,OAAO,aAAa,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AACpC,OAAO,EACL,aAAa,EACb,uBAAuB,EACvB,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,YAAY,EACZ,uBAAuB,EACvB,YAAY,EACb,MAAM,aAAa,CAAC;AAGrB,IAAM,WAAW,GAAG,EAAE,CAAC;AACvB,IAAM,uBAAuB,GAAG,CAAC,CAAC;AAClC,IAAM,WAAW,GAAG,EAAE,CAAC;AAavB;IAAgC,qCAG/B;IACC,2BAAY,KAA6B;QAAzC,YACE,kBAAM,KAAK,CAAC,SASb;QAPK,IAAA,KAAqC,KAAI,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC,EAAnE,QAAQ,cAAA,EAAE,QAAQ,cAAA,EAAE,UAAU,gBAAqC,CAAC;QAE1E,KAAI,CAAC,KAAK,GAAG;YACX,QAAQ,UAAA;YACR,QAAQ,UAAA;YACR,UAAU,YAAA;SACX,CAAC;;IACJ,CAAC;IAED,4DAAgC,GAAhC,UAAiC,SAAiC;QAC5D,IAAA,KAAqC,IAAI,CAAC,aAAa,CACzD,SAAS,CAAC,MAAM,CACjB,EAFK,QAAQ,cAAA,EAAE,QAAQ,cAAA,EAAE,UAAU,gBAEnC,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC;YACZ,QAAQ,UAAA;YACR,QAAQ,UAAA;YACR,UAAU,YAAA;SACX,CAAC,CAAC;IACL,CAAC;IAED,mDAAuB,GAAvB;QACE,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,IAAI,WAAW,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC;IACxE,CAAC;IAED,6CAAiB,GAAjB;QACQ,IAAA,KAA6B,IAAI,CAAC,KAAK,WAAf,EAAxB,UAAU,mBAAG,WAAW,KAAA,CAAgB;QAC9C,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE;YAC/B,OAAO,CAAC,CAAC;SACV;QACD,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE;YACzB,OAAO,UAAU,GAAG,uBAAuB,CAAC;SAC7C;QACD,OAAO,CAAC,GAAG,CAAC,UAAU,GAAG,uBAAuB,CAAC,CAAC;IACpD,CAAC;IAED,wCAAY,GAAZ;QACE,OAAO,SAAS,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,kCAAkC;IAClG,CAAC;IAED,sCAAU,GAAV;QACE,OAAO,uBAAuB,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;IACpE,CAAC;IAED,qDAAyB,GAAzB;QACE,OAAO,SAAS,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC,CAAC;IACxE,CAAC;IAED,kDAAsB,GAAtB;QACE,OAAO,IAAI,CAAC,YAAY,EAAE,CAAC,MAAM,EAAE,CAAC;IACtC,CAAC;IAED,gDAAoB,GAApB;QACE,OAAO,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,MAAM,EAAE,CAAC;IACvD,CAAC;IAED,wCAAY,GAAZ;QACE,IAAM,oBAAoB,GACxB,IAAI,CAAC,KAAK,CAAC,OAAO;YAClB,IAAI,CAAC,sBAAsB,EAAE;YAC7B,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,OAAO,IAAI,CAAC,IAAI,CAAC,oBAAoB,GAAG,YAAY,CAAC,CAAC;IACxD,CAAC;IAED,wCAAY,GAAZ;QACE,OAAO,YAAY,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACvD,CAAC;IAED,oCAAQ,GAAR;QACE,OAAO,CACL,IAAI,CAAC,YAAY,EAAE,GAAG,IAAI,CAAC,uBAAuB,EAAE;YACpD,IAAI,CAAC,KAAK,CAAC,UAAU,CACtB,CAAC;IACJ,CAAC;IAED,qCAAS,GAAT;QACE,OAAO,CACL,IAAI,CAAC,YAAY,EAAE,GAAG,CAAC,IAAI,CAAC,iBAAiB,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CACzE,CAAC;IACJ,CAAC;IAED,yCAAa,GAAb,UAAc,MAAgC;QAA9C,iBA6BC;QA5BC,IAAI,QAAQ,GAAG,QAAQ,EACrB,QAAQ,GAAG,CAAC,QAAQ,CAAC;QAEvB,OAAO;YACL,UAAU,EAAE,MAAM,CAAC,MAAM,CAAC,UAAC,IAAI,EAAE,KAAK;gBACpC,IAAM,IAAI,GAAG,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;gBAEvC,IAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CACtB,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,KAAI,CAAC,yBAAyB,EAAE,CAAC,OAAO,EAAE,CAAC;oBAC3D,uBAAuB,CAC1B,CAAC;gBAEF,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,KAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,CAAC;gBAC1D,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,KAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,CAAC;gBAE1D,IAAI,CAAC,KAAK,CAAC,GAAG;oBACZ,KAAK,OAAA;oBACL,KAAK,EAAE,KAAI,CAAC,KAAK,CAAC,aAAa;wBAC7B,CAAC,CAAC,KAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC;wBACjC,CAAC,CAAC,IAAI;oBACR,gBAAgB,EAAE,KAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC;iBAC1D,CAAC;gBAEF,OAAO,IAAI,CAAC;YACd,CAAC,EAAE,EAAE,CAAC;YACN,QAAQ,UAAA;YACR,QAAQ,UAAA;SACT,CAAC;IACJ,CAAC;IAED,4CAAgB,GAAhB,UAAiB,KAAa;QAC5B,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE;YAChC,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC;SAC3C;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,gDAAoB,GAApB,UAAqB,KAAa;QAChC,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE;YAChC,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE;gBACtC,IAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;gBAEtE,IAAI,KAAK,EAAE;oBACT,IAAM,OAAO,GAAG,QAAQ,CACtB,KAAK,EACL,IAAI,CAAC,KAAK,CAAC,QAAQ,EACnB,IAAI,CAAC,KAAK,CAAC,QAAQ,EACnB,IAAI,GAAG,IAAI,EAAE,mDAAmD;oBAChE,CAAC,CACF,CAAC;oBAEF,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;iBAC9C;aACF;SACF;QAED,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC5C,CAAC;IAED,4CAAgB,GAAhB,UAAiB,KAAa;QAC5B,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE;YAChC,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC;SAC3C;QAED,OAAO,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC1E,CAAC;IAED,uDAA2B,GAA3B,UAA4B,KAAa;;QACvC,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE;YAChC,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,gBAAgB,CAAC;SACtD;QAED,OAAO,IAAI,CAAC,2BAA2B,CAAC,CAAA;gBACtC,IAAI,EAAE,IAAI;;YACV,GAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAG,IAAI;cACF,CAAA,CAAC,CAAC;IAC/B,CAAC;IAED,uDAA2B,GAA3B,UAA4B,KAA6B;QAC/C,IAAA,gBAAgB,GAAK,IAAI,CAAC,KAAK,iBAAf,CAAgB;QAExC,IAAI,OAAO,gBAAgB,KAAK,UAAU,EAAE;YAC1C,OAAO,gBAAgB,CAAC,KAAK,CAAC,CAAC;SAChC;QAED,OAAO,gBAAgB,CAAC;IAC1B,CAAC;IAED,+CAAmB,GAAnB,UAAoB,SAAiB;QACnC,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE;YACzB,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,uBAAuB,EAAE,EAAE,EAAE,CAAC,CAAC;SACzD;QACD,OAAO,CAAC,EAAE,EAAE,SAAS,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAC1D,CAAC;IAED,sDAA0B,GAA1B;QACE,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE;YACzB,OAAO,IAAI,CAAC;SACb;QACD,OAAU,IAAI,CAAC,YAAY,EAAE,GAAG,uBAAuB,QAAK,CAAC;IAC/D,CAAC;IAED,mDAAuB,GAAvB;QACE,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE;YACzB,OAAO,SAAM,IAAI,CAAC,iBAAiB,EAAE,GAAG,GAAG,CAAE,CAAC;SAC/C;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,sCAAU,GAAV;QACE,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE;YACzB,OAAU,IAAI,CAAC,QAAQ,EAAE,SAAI,IAAI,CAAC,SAAS,EAAI,CAAC;SACjD;QACD,OAAU,IAAI,CAAC,SAAS,EAAE,SAAI,IAAI,CAAC,QAAQ,EAAI,CAAC;IAClD,CAAC;IAED,gDAAoB,GAApB,UAAqB,QAAgB;QACnC,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE;YACzB,OAAO,CAAC,CAAC,EAAE,QAAQ,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;SACvD;QACD,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,uBAAuB,EAAE,EAAE,CAAC,CAAC,CAAC;IACxD,CAAC;IAED,oDAAwB,GAAxB,UAAyB,SAAiB;QACxC,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE;YACzB,OAAO;gBACL,SAAS,GAAG,IAAI,CAAC,uBAAuB,EAAE;gBAC1C,IAAI,CAAC,iBAAiB,EAAE,GAAG,uBAAuB;aACnD,CAAC;SACH;QACD,IAAM,cAAc,GAAG,CAAC,CAAC,CAAC;QAC1B,OAAO;YACL,CAAC;YACD,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,uBAAuB,EAAE,GAAG,cAAc;SAClE,CAAC;IACJ,CAAC;IAED,wCAAY,GAAZ,UAAa,QAAgB,EAAE,KAAa;QAA5C,iBA2BC;QA1BC,IAAM,eAAe,GACnB,KAAK,GAAG,IAAI,CAAC,sBAAsB,EAAE;YACrC,KAAK,IAAI,IAAI,CAAC,sBAAsB,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC;QAE9D,IAAI,eAAe,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,kBAAkB,EAAE;YACrD,OAAO,IAAI,CAAC;SACb;QAEK,IAAA,KAAS,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,EAA3C,CAAC,QAAA,EAAE,CAAC,QAAuC,CAAC;QAC3C,IAAA,KAA6B,IAAI,CAAC,KAAK,WAAf,EAAxB,UAAU,mBAAG,WAAW,KAAA,CAAgB;QAEhD,OAAO,CACL,CAAC,IAAI,CACH,GAAG,CAAC,CAAC,KAAK,CAAC,CACX,KAAK,CAAC,CAAC,UAAU,CAAC,CAClB,MAAM,CAAC,CAAC,UAAU,CAAC,CACnB,CAAC,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC,CACnB,CAAC,CAAC,CAAC,CAAC,CAAC,CACL,KAAK,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CACpC,IAAI,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,CACvC,OAAO,CAAC,CAAC;YACP,KAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC7B,CAAC,CAAC,CACF,IAAI,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,CAAC,EAC5C,CACH,CAAC;IACJ,CAAC;IAED,0CAAc,GAAd,UAAe,KAAa;;QAC1B,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE;YAC1B,OAAO;SACR;QAED,IAAI,CAAC,KAAK,CAAC,UAAU,CACnB,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,KAAK;YAChE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,KAAK;YACpC,CAAC;gBACG,GAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAG,CAAC;gBACxB,OAAI,GAAE,IAAI,IAAI,CACZ,IAAI,CAAC,YAAY,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,GAAG,uBAAuB,CAChE;mBACF,CACN,CAAC;IACJ,CAAC;IAED,sCAAU,GAAV,UAAW,SAAiB;QAA5B,iBASC;QARO,IAAA,KAAS,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,EAA3C,CAAC,QAAA,EAAE,CAAC,QAAuC,CAAC;QACnD,OAAO,CACL,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAC5B;QAAA,CAAC,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,UAAA,QAAQ;YACjC,OAAA,KAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,SAAS,GAAG,YAAY,GAAG,QAAQ,CAAC;QAAhE,CAAgE,CACjE,CACH;MAAA,EAAE,CAAC,CAAC,CACL,CAAC;IACJ,CAAC;IAED,0CAAc,GAAd;QAAA,iBAIC;QAHC,OAAO,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,GAAG,CAAC,UAAA,SAAS;YAC/C,OAAA,KAAI,CAAC,UAAU,CAAC,SAAS,CAAC;QAA1B,CAA0B,CAC3B,CAAC;IACJ,CAAC;IAED,6CAAiB,GAAjB;QAAA,iBA4BC;QA3BC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE;YAC/B,OAAO,IAAI,CAAC;SACb;QAED,IAAM,SAAS,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,4DAA4D;QAEhH,OAAO,SAAS,CAAC,GAAG,CAAC,UAAA,SAAS;YAC5B,IAAM,SAAS,GAAG,SAAS,CACzB,KAAI,CAAC,yBAAyB,EAAE,EAChC,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,YAAY,CAC/B,CAAC;YAEI,IAAA,KAAS,KAAI,CAAC,wBAAwB,CAAC,SAAS,CAAC,EAAhD,CAAC,QAAA,EAAE,CAAC,QAA4C,CAAC;YAExD,OAAO,SAAS,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,SAAS,CAAC,OAAO,EAAE,IAAI,YAAY,CAAC,CAAC,CAAC,CACvE,CAAC,IAAI,CACH,GAAG,CAAC,CAAC,SAAS,CAAC,CACf,CAAC,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC,CACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CACT,IAAI,KAAI,CAAC,iBAAiB,EAAE,CAAC,CAE7B;UAAA,CAAC,KAAI,CAAC,KAAK,CAAC,aAAa;gBACvB,CAAC,CAAC,KAAI,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;gBAChD,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,CACxC;QAAA,EAAE,IAAI,CAAC,CACR,CAAC,CAAC,CAAC,IAAI,CAAC;QACX,CAAC,CAAC,CAAC;IACL,CAAC;IAeD,kCAAM,GAAN;QACU,IAAA,KAAK,GAAK,IAAI,CAAC,KAAK,MAAf,CAAgB;QAEvB,IAAA,KAAqB,KAAK,aAAV,EAAhB,YAAY,mBAAG,CAAC,KAAA,CAAW;QAEjC,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,KAAK,EAAE;YACjD,IAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,YAAY,CAAC;YAC3D,YAAY,GAAG,QAAQ,CAAC;SACzB;QAED,OAAO,CACL,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CACjB;QAAA,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CACtD;UAAA,CAAC,IAAI,CAAC,UAAU,YACd,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,EACvB,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,IACtB,IAAI,CAAC,KAAK,CAAC,WAAW,EACzB,CACF;UAAA,CAAC,IAAI,CACH,KAAK,CAAC,MAAM,CACZ,MAAM,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAC1B,EAAE,CAAC,CAAC,YAAY,CAAC,CACjB,EAAE,CAAC,CAAC,YAAY,CAAC,CACjB,IAAI,CAAC,0BAA0B,EAEjC;UAAA,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,EAAE,CAAC,CAChC;UAAA,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,EAAE,CAAC,CAC/B;QAAA,EAAE,GAAG,CACP;MAAA,EAAE,IAAI,CAAC,CACR,CAAC;IACJ,CAAC;IA3Ca,8BAAY,GAAG;QAC3B,OAAO,EAAE,GAAG;QACZ,OAAO,EAAE,IAAI,IAAI,EAAE;QACnB,UAAU,EAAE,CAAC;QACb,UAAU,EAAE,WAAW;QACvB,UAAU,EAAE,IAAI;QAChB,eAAe,EAAE,IAAI;QACrB,kBAAkB,EAAE,KAAK;QACzB,QAAQ,EAAE,OAAO;QACjB,aAAa,EAAE,UAAA,KAAK,IAAI,OAAA,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,EAA7B,CAA6B;QACrD,KAAK,EAAE,EAAE;KACV,CAAC;IAiCJ,wBAAC;CAAA,AA3WD,CAAgC,aAAa,GA2W5C;AAED,eAAe,iBAAiB,CAAC","sourcesContent":["import _ from \"lodash\";\nimport React from \"react\";\nimport { View } from \"react-native\";\nimport { G, Rect, RectProps, Svg, Text } from \"react-native-svg\";\n\nimport AbstractChart from \"../AbstractChart\";\nimport { mapValue } from \"../Utils\";\nimport {\n  convertToDate,\n  getBeginningTimeForDate,\n  shiftDate\n} from \"./DateHelpers\";\nimport {\n  DAYS_IN_WEEK,\n  MILLISECONDS_IN_ONE_DAY,\n  MONTH_LABELS\n} from \"./constants\";\nimport { ContributionGraphProps, ContributionGraphState } from \".\";\n\nconst SQUARE_SIZE = 20;\nconst MONTH_LABEL_GUTTER_SIZE = 8;\nconst paddingLeft = 32;\n\nexport type ContributionChartValue = {\n  value: number;\n  title: string;\n  tooltipDataAttrs: TooltipDataAttrs;\n  date: Date;\n};\n\nexport type TooltipDataAttrs = (\n  value: ContributionChartValue\n) => Partial<RectProps> | Partial<RectProps>;\n\nclass ContributionGraph extends AbstractChart<\n  ContributionGraphProps,\n  ContributionGraphState\n> {\n  constructor(props: ContributionGraphProps) {\n    super(props);\n\n    let { maxValue, minValue, valueCache } = this.getValueCache(props.values);\n\n    this.state = {\n      maxValue,\n      minValue,\n      valueCache\n    };\n  }\n\n  UNSAFE_componentWillReceiveProps(nextProps: ContributionGraphProps) {\n    let { maxValue, minValue, valueCache } = this.getValueCache(\n      nextProps.values\n    );\n\n    this.setState({\n      maxValue,\n      minValue,\n      valueCache\n    });\n  }\n\n  getSquareSizeWithGutter() {\n    return (this.props.squareSize || SQUARE_SIZE) + this.props.gutterSize;\n  }\n\n  getMonthLabelSize() {\n    let { squareSize = SQUARE_SIZE } = this.props;\n    if (!this.props.showMonthLabels) {\n      return 0;\n    }\n    if (this.props.horizontal) {\n      return squareSize + MONTH_LABEL_GUTTER_SIZE;\n    }\n    return 2 * (squareSize + MONTH_LABEL_GUTTER_SIZE);\n  }\n\n  getStartDate() {\n    return shiftDate(this.getEndDate(), -this.props.numDays + 1); // +1 because endDate is inclusive\n  }\n\n  getEndDate() {\n    return getBeginningTimeForDate(convertToDate(this.props.endDate));\n  }\n\n  getStartDateWithEmptyDays() {\n    return shiftDate(this.getStartDate(), -this.getNumEmptyDaysAtStart());\n  }\n\n  getNumEmptyDaysAtStart() {\n    return this.getStartDate().getDay();\n  }\n\n  getNumEmptyDaysAtEnd() {\n    return DAYS_IN_WEEK - 1 - this.getEndDate().getDay();\n  }\n\n  getWeekCount() {\n    const numDaysRoundedToWeek =\n      this.props.numDays +\n      this.getNumEmptyDaysAtStart() +\n      this.getNumEmptyDaysAtEnd();\n    return Math.ceil(numDaysRoundedToWeek / DAYS_IN_WEEK);\n  }\n\n  getWeekWidth() {\n    return DAYS_IN_WEEK * this.getSquareSizeWithGutter();\n  }\n\n  getWidth() {\n    return (\n      this.getWeekCount() * this.getSquareSizeWithGutter() -\n      this.props.gutterSize\n    );\n  }\n\n  getHeight() {\n    return (\n      this.getWeekWidth() + (this.getMonthLabelSize() - this.props.gutterSize)\n    );\n  }\n\n  getValueCache(values: ContributionChartValue[]) {\n    let minValue = Infinity,\n      maxValue = -Infinity;\n\n    return {\n      valueCache: values.reduce((memo, value) => {\n        const date = convertToDate(value.date);\n\n        const index = Math.floor(\n          (date.valueOf() - this.getStartDateWithEmptyDays().valueOf()) /\n            MILLISECONDS_IN_ONE_DAY\n        );\n\n        minValue = Math.min(value[this.props.accessor], minValue);\n        maxValue = Math.max(value[this.props.accessor], maxValue);\n\n        memo[index] = {\n          value,\n          title: this.props.titleForValue\n            ? this.props.titleForValue(value)\n            : null,\n          tooltipDataAttrs: this.getTooltipDataAttrsForValue(value)\n        };\n\n        return memo;\n      }, {}),\n      minValue,\n      maxValue\n    };\n  }\n\n  getValueForIndex(index: number) {\n    if (this.state.valueCache[index]) {\n      return this.state.valueCache[index].value;\n    }\n    return null;\n  }\n\n  getClassNameForIndex(index: number) {\n    if (this.state.valueCache[index]) {\n      if (this.state.valueCache[index].value) {\n        const count = this.state.valueCache[index].value[this.props.accessor];\n\n        if (count) {\n          const opacity = mapValue(\n            count,\n            this.state.minValue,\n            this.state.maxValue,\n            0.15 + 0.05, // + 0.05 to make smaller values a bit more visible\n            1\n          );\n\n          return this.props.chartConfig.color(opacity);\n        }\n      }\n    }\n\n    return this.props.chartConfig.color(0.15);\n  }\n\n  getTitleForIndex(index: number) {\n    if (this.state.valueCache[index]) {\n      return this.state.valueCache[index].title;\n    }\n\n    return this.props.titleForValue ? this.props.titleForValue(null) : null;\n  }\n\n  getTooltipDataAttrsForIndex(index: number) {\n    if (this.state.valueCache[index]) {\n      return this.state.valueCache[index].tooltipDataAttrs;\n    }\n\n    return this.getTooltipDataAttrsForValue({\n      date: null,\n      [this.props.accessor]: null\n    } as ContributionChartValue);\n  }\n\n  getTooltipDataAttrsForValue(value: ContributionChartValue) {\n    const { tooltipDataAttrs } = this.props;\n\n    if (typeof tooltipDataAttrs === \"function\") {\n      return tooltipDataAttrs(value);\n    }\n\n    return tooltipDataAttrs;\n  }\n\n  getTransformForWeek(weekIndex: number) {\n    if (this.props.horizontal) {\n      return [weekIndex * this.getSquareSizeWithGutter(), 50];\n    }\n    return [10, weekIndex * this.getSquareSizeWithGutter()];\n  }\n\n  getTransformForMonthLabels() {\n    if (this.props.horizontal) {\n      return null;\n    }\n    return `${this.getWeekWidth() + MONTH_LABEL_GUTTER_SIZE}, 0`;\n  }\n\n  getTransformForAllWeeks() {\n    if (this.props.horizontal) {\n      return `0, ${this.getMonthLabelSize() - 100}`;\n    }\n    return null;\n  }\n\n  getViewBox() {\n    if (this.props.horizontal) {\n      return `${this.getWidth()} ${this.getHeight()}`;\n    }\n    return `${this.getHeight()} ${this.getWidth()}`;\n  }\n\n  getSquareCoordinates(dayIndex: number) {\n    if (this.props.horizontal) {\n      return [0, dayIndex * this.getSquareSizeWithGutter()];\n    }\n    return [dayIndex * this.getSquareSizeWithGutter(), 0];\n  }\n\n  getMonthLabelCoordinates(weekIndex: number) {\n    if (this.props.horizontal) {\n      return [\n        weekIndex * this.getSquareSizeWithGutter(),\n        this.getMonthLabelSize() - MONTH_LABEL_GUTTER_SIZE\n      ];\n    }\n    const verticalOffset = -2;\n    return [\n      0,\n      (weekIndex + 1) * this.getSquareSizeWithGutter() + verticalOffset\n    ];\n  }\n\n  renderSquare(dayIndex: number, index: number) {\n    const indexOutOfRange =\n      index < this.getNumEmptyDaysAtStart() ||\n      index >= this.getNumEmptyDaysAtStart() + this.props.numDays;\n\n    if (indexOutOfRange && !this.props.showOutOfRangeDays) {\n      return null;\n    }\n\n    const [x, y] = this.getSquareCoordinates(dayIndex);\n    const { squareSize = SQUARE_SIZE } = this.props;\n\n    return (\n      <Rect\n        key={index}\n        width={squareSize}\n        height={squareSize}\n        x={x + paddingLeft}\n        y={y}\n        title={this.getTitleForIndex(index)}\n        fill={this.getClassNameForIndex(index)}\n        onPress={() => {\n          this.handleDayPress(index);\n        }}\n        {...this.getTooltipDataAttrsForIndex(index)}\n      />\n    );\n  }\n\n  handleDayPress(index: number) {\n    if (!this.props.onDayPress) {\n      return;\n    }\n\n    this.props.onDayPress(\n      this.state.valueCache[index] && this.state.valueCache[index].value\n        ? this.state.valueCache[index].value\n        : {\n            [this.props.accessor]: 0,\n            date: new Date(\n              this.getStartDate().valueOf() + index * MILLISECONDS_IN_ONE_DAY\n            )\n          }\n    );\n  }\n\n  renderWeek(weekIndex: number) {\n    const [x, y] = this.getTransformForWeek(weekIndex);\n    return (\n      <G key={weekIndex} x={x} y={y}>\n        {_.range(DAYS_IN_WEEK).map(dayIndex =>\n          this.renderSquare(dayIndex, weekIndex * DAYS_IN_WEEK + dayIndex)\n        )}\n      </G>\n    );\n  }\n\n  renderAllWeeks() {\n    return _.range(this.getWeekCount()).map(weekIndex =>\n      this.renderWeek(weekIndex)\n    );\n  }\n\n  renderMonthLabels() {\n    if (!this.props.showMonthLabels) {\n      return null;\n    }\n\n    const weekRange = _.range(this.getWeekCount() - 1); // don't render for last week, because label will be cut off\n\n    return weekRange.map(weekIndex => {\n      const endOfWeek = shiftDate(\n        this.getStartDateWithEmptyDays(),\n        (weekIndex + 1) * DAYS_IN_WEEK\n      );\n\n      const [x, y] = this.getMonthLabelCoordinates(weekIndex);\n\n      return endOfWeek.getDate() >= 1 && endOfWeek.getDate() <= DAYS_IN_WEEK ? (\n        <Text\n          key={weekIndex}\n          x={x + paddingLeft}\n          y={y + 8}\n          {...this.getPropsForLabels()}\n        >\n          {this.props.getMonthLabel\n            ? this.props.getMonthLabel(endOfWeek.getMonth())\n            : MONTH_LABELS[endOfWeek.getMonth()]}\n        </Text>\n      ) : null;\n    });\n  }\n\n  public static defaultProps = {\n    numDays: 200,\n    endDate: new Date(),\n    gutterSize: 1,\n    squareSize: SQUARE_SIZE,\n    horizontal: true,\n    showMonthLabels: true,\n    showOutOfRangeDays: false,\n    accessor: \"count\",\n    classForValue: value => (value ? \"black\" : \"#8cc665\"),\n    style: {}\n  };\n\n  render() {\n    const { style } = this.props;\n\n    let { borderRadius = 0 } = style;\n\n    if (!borderRadius && this.props.chartConfig.style) {\n      const stupidXo = this.props.chartConfig.style.borderRadius;\n      borderRadius = stupidXo;\n    }\n\n    return (\n      <View style={style}>\n        <Svg height={this.props.height} width={this.props.width}>\n          {this.renderDefs({\n            width: this.props.width,\n            height: this.props.height,\n            ...this.props.chartConfig\n          })}\n          <Rect\n            width=\"100%\"\n            height={this.props.height}\n            rx={borderRadius}\n            ry={borderRadius}\n            fill=\"url(#backgroundGradient)\"\n          />\n          <G>{this.renderMonthLabels()}</G>\n          <G>{this.renderAllWeeks()}</G>\n        </Svg>\n      </View>\n    );\n  }\n}\n\nexport default ContributionGraph;\n"]} |
\ | No newline at end of file |