UNPKG

@uiw/react-heat-map

Version:

React component create calendar heatmap to visualize time series data, a la github contribution graph.

70 lines (60 loc) 2.44 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.LablesMonth = void 0; var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _react = _interopRequireWildcard(require("react")); var _utils = require("./utils"); var _jsxRuntime = require("react/jsx-runtime"); var LablesMonth = function LablesMonth(_ref) { var _ref$monthLables = _ref.monthLables, monthLables = _ref$monthLables === void 0 ? [] : _ref$monthLables, _ref$rectSize = _ref.rectSize, rectSize = _ref$rectSize === void 0 ? 0 : _ref$rectSize, _ref$space = _ref.space, space = _ref$space === void 0 ? 0 : _ref$space, _ref$leftPad = _ref.leftPad, leftPad = _ref$leftPad === void 0 ? 0 : _ref$leftPad, _ref$colNum = _ref.colNum, colNum = _ref$colNum === void 0 ? 0 : _ref$colNum, startDate = _ref.startDate; var data = (0, _react.useMemo)(function () { if (monthLables === false || colNum < 1) return []; return (0, _toConsumableArray2.default)(Array(colNum * 7)).map(function (_, idx) { if (idx / 7 % 1 === 0) { var date = new Date(startDate.getTime() + idx * _utils.oneDayTime); var month = date.getMonth(); return { col: idx / 7, index: idx, month: month, day: date.getDate(), monthStr: monthLables[month], date: date }; } return null; }).filter(Boolean).filter(function (item, idx, list) { return list[idx - 1] && list[idx - 1].month !== item.month; }); }, [colNum, monthLables, startDate]); return (0, _react.useMemo)(function () { return /*#__PURE__*/(0, _jsxRuntime.jsx)(_react.Fragment, { children: (0, _toConsumableArray2.default)(data).map(function (item, idx) { return /*#__PURE__*/(0, _jsxRuntime.jsx)("text", { "data-size": rectSize, x: leftPad + space + space, y: 15, dx: item.col * (rectSize + space), textAnchor: "start", children: item.monthStr }, idx); }) }); }, [data, leftPad, rectSize, space]); }; exports.LablesMonth = LablesMonth; //# sourceMappingURL=LablesMonth.js.map