UNPKG

react-native-chart-kit

Version:

If you're looking to **build a website or a cross-platform mobile app** – we will be happy to help you! Send a note to clients@ui1.io and we will be in touch with you shortly.

296 lines 41.4 kB
var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); var __assign = (this && this.__assign) || function () { __assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return __assign.apply(this, arguments); }; import _ from "lodash"; import React from "react"; import { View } from "react-native"; import { G, Rect, Svg, Text } from "react-native-svg"; import AbstractChart from "../AbstractChart"; import { mapValue } from "../Utils"; import { convertToDate, getBeginningTimeForDate, shiftDate } from "./DateHelpers"; import { DAYS_IN_WEEK, MILLISECONDS_IN_ONE_DAY, MONTH_LABELS } from "./constants"; var SQUARE_SIZE = 20; var MONTH_LABEL_GUTTER_SIZE = 8; var paddingLeft = 32; var ContributionGraph = /** @class */ (function (_super) { __extends(ContributionGraph, _super); function ContributionGraph(props) { var _this = _super.call(this, props) || this; var _a = _this.getValueCache(props.values), maxValue = _a.maxValue, minValue = _a.minValue, valueCache = _a.valueCache; _this.state = { maxValue: maxValue, minValue: minValue, valueCache: valueCache }; return _this; } ContributionGraph.prototype.UNSAFE_componentWillReceiveProps = function (nextProps) { var _a = this.getValueCache(nextProps.values), maxValue = _a.maxValue, minValue = _a.minValue, valueCache = _a.valueCache; this.setState({ maxValue: maxValue, minValue: minValue, valueCache: valueCache }); }; ContributionGraph.prototype.getSquareSizeWithGutter = function () { return (this.props.squareSize || SQUARE_SIZE) + this.props.gutterSize; }; ContributionGraph.prototype.getMonthLabelSize = function () { var _a = this.props.squareSize, squareSize = _a === void 0 ? SQUARE_SIZE : _a; if (!this.props.showMonthLabels) { return 0; } if (this.props.horizontal) { return squareSize + MONTH_LABEL_GUTTER_SIZE; } return 2 * (squareSize + MONTH_LABEL_GUTTER_SIZE); }; ContributionGraph.prototype.getStartDate = function () { return shiftDate(this.getEndDate(), -this.props.numDays + 1); // +1 because endDate is inclusive }; ContributionGraph.prototype.getEndDate = function () { return getBeginningTimeForDate(convertToDate(this.props.endDate)); }; ContributionGraph.prototype.getStartDateWithEmptyDays = function () { return shiftDate(this.getStartDate(), -this.getNumEmptyDaysAtStart()); }; ContributionGraph.prototype.getNumEmptyDaysAtStart = function () { return this.getStartDate().getDay(); }; ContributionGraph.prototype.getNumEmptyDaysAtEnd = function () { return DAYS_IN_WEEK - 1 - this.getEndDate().getDay(); }; ContributionGraph.prototype.getWeekCount = function () { var numDaysRoundedToWeek = this.props.numDays + this.getNumEmptyDaysAtStart() + this.getNumEmptyDaysAtEnd(); return Math.ceil(numDaysRoundedToWeek / DAYS_IN_WEEK); }; ContributionGraph.prototype.getWeekWidth = function () { return DAYS_IN_WEEK * this.getSquareSizeWithGutter(); }; ContributionGraph.prototype.getWidth = function () { return (this.getWeekCount() * this.getSquareSizeWithGutter() - this.props.gutterSize); }; ContributionGraph.prototype.getHeight = function () { return (this.getWeekWidth() + (this.getMonthLabelSize() - this.props.gutterSize)); }; ContributionGraph.prototype.getValueCache = function (values) { var _this = this; var minValue = Infinity, maxValue = -Infinity; return { valueCache: values.reduce(function (memo, value) { var date = convertToDate(value.date); var index = Math.floor((date.valueOf() - _this.getStartDateWithEmptyDays().valueOf()) / MILLISECONDS_IN_ONE_DAY); minValue = Math.min(value[_this.props.accessor], minValue); maxValue = Math.max(value[_this.props.accessor], maxValue); memo[index] = { value: value, title: _this.props.titleForValue ? _this.props.titleForValue(value) : null, tooltipDataAttrs: _this.getTooltipDataAttrsForValue(value) }; return memo; }, {}), minValue: minValue, maxValue: maxValue }; }; ContributionGraph.prototype.getValueForIndex = function (index) { if (this.state.valueCache[index]) { return this.state.valueCache[index].value; } return null; }; ContributionGraph.prototype.getClassNameForIndex = function (index) { if (this.state.valueCache[index]) { if (this.state.valueCache[index].value) { var count = this.state.valueCache[index].value[this.props.accessor]; if (count) { var opacity = mapValue(count, this.state.maxValue === this.state.minValue ? 0 : this.state.minValue, isNaN(this.state.maxValue) ? 1 : this.state.maxValue, 0.15 + 0.05, // + 0.05 to make smaller values a bit more visible 1); return this.props.chartConfig.color(opacity); } } } return this.props.chartConfig.color(0.15); }; ContributionGraph.prototype.getTitleForIndex = function (index) { if (this.state.valueCache[index]) { return this.state.valueCache[index].title; } return this.props.titleForValue ? this.props.titleForValue(null) : null; }; ContributionGraph.prototype.getTooltipDataAttrsForIndex = function (index) { var _a; if (this.state.valueCache[index]) { return this.state.valueCache[index].tooltipDataAttrs; } return this.getTooltipDataAttrsForValue((_a = { date: null }, _a[this.props.accessor] = null, _a)); }; ContributionGraph.prototype.getTooltipDataAttrsForValue = function (value) { var tooltipDataAttrs = this.props.tooltipDataAttrs; if (typeof tooltipDataAttrs === "function") { return tooltipDataAttrs(value); } return tooltipDataAttrs; }; ContributionGraph.prototype.getTransformForWeek = function (weekIndex) { if (this.props.horizontal) { return [weekIndex * this.getSquareSizeWithGutter(), 50]; } return [10, weekIndex * this.getSquareSizeWithGutter()]; }; ContributionGraph.prototype.getTransformForMonthLabels = function () { if (this.props.horizontal) { return null; } return this.getWeekWidth() + MONTH_LABEL_GUTTER_SIZE + ", 0"; }; ContributionGraph.prototype.getTransformForAllWeeks = function () { if (this.props.horizontal) { return "0, " + (this.getMonthLabelSize() - 100); } return null; }; ContributionGraph.prototype.getViewBox = function () { if (this.props.horizontal) { return this.getWidth() + " " + this.getHeight(); } return this.getHeight() + " " + this.getWidth(); }; ContributionGraph.prototype.getSquareCoordinates = function (dayIndex) { if (this.props.horizontal) { return [0, dayIndex * this.getSquareSizeWithGutter()]; } return [dayIndex * this.getSquareSizeWithGutter(), 0]; }; ContributionGraph.prototype.getMonthLabelCoordinates = function (weekIndex) { if (this.props.horizontal) { return [ weekIndex * this.getSquareSizeWithGutter(), this.getMonthLabelSize() - MONTH_LABEL_GUTTER_SIZE ]; } var verticalOffset = -2; return [ 0, (weekIndex + 1) * this.getSquareSizeWithGutter() + verticalOffset ]; }; ContributionGraph.prototype.renderSquare = function (dayIndex, index) { var _this = this; var indexOutOfRange = index < this.getNumEmptyDaysAtStart() || index >= this.getNumEmptyDaysAtStart() + this.props.numDays; if (indexOutOfRange && !this.props.showOutOfRangeDays) { return null; } var _a = this.getSquareCoordinates(dayIndex), x = _a[0], y = _a[1]; var _b = this.props.squareSize, squareSize = _b === void 0 ? SQUARE_SIZE : _b; return (<Rect key={index} width={squareSize} height={squareSize} x={x + paddingLeft} y={y} title={this.getTitleForIndex(index)} fill={this.getClassNameForIndex(index)} onPress={function () { _this.handleDayPress(index); }} {...this.getTooltipDataAttrsForIndex(index)}/>); }; ContributionGraph.prototype.handleDayPress = function (index) { var _a; if (!this.props.onDayPress) { return; } this.props.onDayPress(this.state.valueCache[index] && this.state.valueCache[index].value ? this.state.valueCache[index].value : (_a = {}, _a[this.props.accessor] = 0, _a.date = new Date(this.getStartDate().valueOf() + index * MILLISECONDS_IN_ONE_DAY), _a)); }; ContributionGraph.prototype.renderWeek = function (weekIndex) { var _this = this; var _a = this.getTransformForWeek(weekIndex), x = _a[0], y = _a[1]; return (<G key={weekIndex} x={x} y={y}> {_.range(DAYS_IN_WEEK).map(function (dayIndex) { return _this.renderSquare(dayIndex, weekIndex * DAYS_IN_WEEK + dayIndex); })} </G>); }; ContributionGraph.prototype.renderAllWeeks = function () { var _this = this; return _.range(this.getWeekCount()).map(function (weekIndex) { return _this.renderWeek(weekIndex); }); }; ContributionGraph.prototype.renderMonthLabels = function () { var _this = this; if (!this.props.showMonthLabels) { return null; } var weekRange = _.range(this.getWeekCount() - 1); // don't render for last week, because label will be cut off return weekRange.map(function (weekIndex) { var endOfWeek = shiftDate(_this.getStartDateWithEmptyDays(), (weekIndex + 1) * DAYS_IN_WEEK); var _a = _this.getMonthLabelCoordinates(weekIndex), x = _a[0], y = _a[1]; return endOfWeek.getDate() >= 1 && endOfWeek.getDate() <= DAYS_IN_WEEK ? (<Text key={weekIndex} x={x + paddingLeft} y={y + 8} {..._this.getPropsForLabels()}> {_this.props.getMonthLabel ? _this.props.getMonthLabel(endOfWeek.getMonth()) : MONTH_LABELS[endOfWeek.getMonth()]} </Text>) : null; }); }; ContributionGraph.prototype.render = function () { var style = this.props.style; var _a = style.borderRadius, borderRadius = _a === void 0 ? 0 : _a; if (!borderRadius && this.props.chartConfig.style) { var stupidXo = this.props.chartConfig.style.borderRadius; borderRadius = stupidXo; } return (<View style={style}> <Svg height={this.props.height} width={this.props.width}> {this.renderDefs(__assign({ width: this.props.width, height: this.props.height }, this.props.chartConfig))} <Rect width="100%" height={this.props.height} rx={borderRadius} ry={borderRadius} fill="url(#backgroundGradient)"/> <G>{this.renderMonthLabels()}</G> <G>{this.renderAllWeeks()}</G> </Svg> </View>); }; ContributionGraph.defaultProps = { numDays: 200, endDate: new Date(), gutterSize: 1, squareSize: SQUARE_SIZE, horizontal: true, showMonthLabels: true, showOutOfRangeDays: false, accessor: "count", classForValue: function (value) { return (value ? "black" : "#8cc665"); }, style: {} }; return ContributionGraph; }(AbstractChart)); export default ContributionGraph; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ContributionGraph.js","sourceRoot":"","sources":["../../src/contribution-graph/ContributionGraph.tsx"],"names":[],"mappings":"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","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.maxValue === this.state.minValue ? 0: this.state.minValue,\n            isNaN(this.state.maxValue) ? 1 : 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"]}