Socket
Socket
Sign inDemoInstall

@uiw/react-heat-map

Package Overview
Dependencies
Maintainers
1
Versions
31
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@uiw/react-heat-map - npm Package Compare versions

Comparing version 1.0.3 to 1.1.0

lib/cjs/LablesMonth.d.ts

9

lib/cjs/Rect.js

@@ -10,14 +10,9 @@ "use strict";

var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _react = _interopRequireDefault(require("react"));
var Rect = function Rect(props) {
return /*#__PURE__*/_react.default.createElement("rect", (0, _extends2.default)({}, props, {
rx: "2",
ry: "2"
}));
return /*#__PURE__*/_react.default.createElement("rect", props);
};
exports.Rect = Rect;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9SZWN0LnRzeCJdLCJuYW1lcyI6WyJSZWN0IiwicHJvcHMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBQUE7O0FBR08sSUFBTUEsSUFBSSxHQUFHLFNBQVBBLElBQU8sQ0FBQ0MsS0FBRDtBQUFBLHNCQUFzQixnRUFBVUEsS0FBVjtBQUFpQixJQUFBLEVBQUUsRUFBQyxHQUFwQjtBQUF3QixJQUFBLEVBQUUsRUFBQztBQUEzQixLQUF0QjtBQUFBLENBQWIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFJlY3RQcm9wcyBleHRlbmRzIFJlYWN0LlNWR1Byb3BzPFNWR1JlY3RFbGVtZW50PiB7fVxuZXhwb3J0IGNvbnN0IFJlY3QgPSAocHJvcHM6IFJlY3RQcm9wcykgPT4gPHJlY3Qgey4uLnByb3BzfSByeD1cIjJcIiByeT1cIjJcIiAvPjtcbiJdfQ==
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9SZWN0LnRzeCJdLCJuYW1lcyI6WyJSZWN0IiwicHJvcHMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBOztBQUdPLElBQU1BLElBQUksR0FBRyxTQUFQQSxJQUFPLENBQUNDLEtBQUQ7QUFBQSxzQkFBc0IscUNBQVVBLEtBQVYsQ0FBdEI7QUFBQSxDQUFiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuZXhwb3J0IGludGVyZmFjZSBSZWN0UHJvcHMgZXh0ZW5kcyBSZWFjdC5TVkdQcm9wczxTVkdSZWN0RWxlbWVudD4ge31cbmV4cG9ydCBjb25zdCBSZWN0ID0gKHByb3BzOiBSZWN0UHJvcHMpID0+IDxyZWN0IHsuLi5wcm9wc30gLz47XG4iXX0=

@@ -13,2 +13,3 @@ import React from 'react';

rectSize?: number;
legendCellSize?: number;
space?: number;

@@ -18,8 +19,8 @@ rectProps?: RectDayElement | RectDayDefaultProps;

fill?: string;
}) => React.ReactElement | void;
}, valueItem?: HeatMapValue) => React.ReactElement | void;
value?: Array<HeatMapValue>;
weekLables?: string[] | false;
monthLables?: string[];
monthLables?: string[] | false;
panelColors?: Record<number, string>;
}
export default function SVG(props: SVGProps): JSX.Element;

@@ -24,4 +24,6 @@ "use strict";

var _WeekLables = require("./WeekLables");
var _LablesWeek = require("./LablesWeek");
var _LablesMonth = require("./LablesMonth");
var _RectDay = require("./RectDay");

@@ -31,3 +33,3 @@

var oneDayTime = 24 * 60 * 60 * 1000;
var _Legend = _interopRequireDefault(require("./Legend"));

@@ -38,2 +40,4 @@ function SVG(props) {

rectSize = _ref$rectSize === void 0 ? 11 : _ref$rectSize,
_ref$legendCellSize = _ref.legendCellSize,
legendCellSize = _ref$legendCellSize === void 0 ? 11 : _ref$legendCellSize,
_ref$space = _ref.space,

@@ -60,3 +64,3 @@ space = _ref$space === void 0 ? 2 : _ref$space,

} : _ref$panelColors,
other = (0, _objectWithoutProperties2.default)(_ref, ["rectSize", "space", "startDate", "endDate", "rectProps", "renderRect", "value", "weekLables", "monthLables", "panelColors"]);
other = (0, _objectWithoutProperties2.default)(_ref, ["rectSize", "legendCellSize", "space", "startDate", "endDate", "rectProps", "renderRect", "value", "weekLables", "monthLables", "panelColors"]);

@@ -73,2 +77,7 @@ var _useState = (0, _react.useState)(0),

var _useState5 = (0, _react.useState)(!!monthLables ? 20 : 5),
_useState6 = (0, _slicedToArray2.default)(_useState5, 2),
topPad = _useState6[0],
setTopPad = _useState6[1];
var svgRef = /*#__PURE__*/_react.default.createRef();

@@ -93,8 +102,11 @@

}, [rectSize, svgRef, space, leftPad]);
(0, _react.useEffect)(function () {
setTopPad(!!monthLables ? 20 : 5);
}, [monthLables]);
var initStartDate = (0, _react.useMemo)(function () {
if ((0, _utils.isValidDate)(startDate)) {
return !startDate.getDay() ? startDate : new Date(startDate.getTime() - startDate.getDay() * oneDayTime);
return !startDate.getDay() ? startDate : new Date(startDate.getTime() - startDate.getDay() * _utils.oneDayTime);
} else {
var newDate = new Date();
return new Date(newDate.getTime() - newDate.getDay() * oneDayTime);
return new Date(newDate.getTime() - newDate.getDay() * _utils.oneDayTime);
}

@@ -104,8 +116,23 @@ }, [startDate]);

ref: svgRef
}, other), /*#__PURE__*/_react.default.createElement(_WeekLables.WeekLables, {
}, other), legendCellSize !== 0 && /*#__PURE__*/_react.default.createElement(_Legend.default, {
panelColors: panelColors,
rectSize: rectSize,
legendCellSize: legendCellSize,
leftPad: leftPad,
topPad: topPad,
space: space
}), /*#__PURE__*/_react.default.createElement(_LablesWeek.LablesWeek, {
weekLables: weekLables,
rectSize: rectSize,
space: space
space: space,
topPad: topPad
}), /*#__PURE__*/_react.default.createElement(_LablesMonth.LablesMonth, {
monthLables: monthLables,
rectSize: rectSize,
space: space,
leftPad: leftPad,
colNum: gridNum,
startDate: initStartDate
}), /*#__PURE__*/_react.default.createElement("g", {
transform: "translate(".concat(leftPad, ", 20)")
transform: "translate(".concat(leftPad, ", ").concat(topPad, ")")
}, (0, _toConsumableArray2.default)(Array(gridNum)).map(function (_, idx) {

@@ -124,3 +151,3 @@ return /*#__PURE__*/_react.default.createElement("g", {

});
var currentDate = new Date(initStartDate.getTime() + oneDayTime * (idx * 7 + cidx));
var currentDate = new Date(initStartDate.getTime() + _utils.oneDayTime * (idx * 7 + cidx));
dayProps.date = (0, _utils.getDateToString)(currentDate);

@@ -139,3 +166,3 @@

if (renderRect && typeof renderRect === 'function') {
var elm = renderRect(dayProps);
var elm = renderRect(dayProps, data[dayProps.date]);

@@ -153,2 +180,2 @@ if (elm && /*#__PURE__*/_react.default.isValidElement(elm)) {

module.exports = exports.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/SVG.tsx"],"names":["oneDayTime","SVG","props","rectSize","space","startDate","Date","endDate","rectProps","renderRect","value","weekLables","monthLables","panelColors","other","gridNum","setGridNum","leftPad","setLeftPad","svgRef","React","createRef","nums","Object","keys","map","item","parseInt","data","current","width","clientWidth","Math","floor","initStartDate","getDay","getTime","newDate","Array","_","idx","cidx","dayProps","key","row","column","fill","currentDate","date","length","count","elm","isValidElement"],"mappings":"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","sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport { WeekLables } from './WeekLables';\nimport { RectDay, RectDayDefaultProps } from './RectDay';\nimport { formatData, getDateToString, existColor, numberSort, isValidDate } from './utils';\n\nconst oneDayTime = 24 * 60 * 60 * 1000;\n\nexport type HeatMapValue = {\n  date: string;\n  content: string | string[] | React.ReactNode;\n  count: number;\n};\n\nexport type RectDayElement<T = SVGRectElement> = RectDayDefaultProps & React.SVGProps<T>;\n\nexport interface SVGProps extends React.SVGProps<SVGSVGElement> {\n  startDate?: Date;\n  endDate?: Date;\n  rectSize?: number;\n  space?: number;\n  rectProps?: RectDayElement | RectDayDefaultProps;\n  renderRect?: <E = SVGRectElement>(data: E & RectDayDefaultProps & { fill?: string }) => React.ReactElement | void;\n  value?: Array<HeatMapValue>;\n  weekLables?: string[] | false;\n  monthLables?: string[];\n  panelColors?: Record<number, string>;\n}\n\nexport default function SVG(props: SVGProps) {\n  const {\n    rectSize = 11,\n    space = 2,\n    startDate = new Date(),\n    endDate,\n    rectProps,\n    renderRect,\n    value = [],\n    weekLables = ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n    monthLables = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n    panelColors = { 0: '#EBEDF0', 8: '#7BC96F', 4: '#C6E48B', 12: '#239A3B', 32: '#196127' },\n    ...other\n  } = props || {};\n  const [gridNum, setGridNum] = useState(0);\n  const [leftPad, setLeftPad] = useState(!!weekLables ? 28 : 5);\n  const svgRef = React.createRef<SVGSVGElement>();\n  const nums = useMemo(() => numberSort(Object.keys(panelColors).map((item) => parseInt(item, 10))), [panelColors]);\n  const data = useMemo(() => formatData(value), [value]);\n  useEffect(() => setLeftPad(!!weekLables ? 28 : 5), [weekLables]);\n  useEffect(() => {\n    if (svgRef.current) {\n      const width = svgRef.current.clientWidth - leftPad || 0;\n      setGridNum(Math.floor(width / (rectSize + space)) || 0);\n    }\n  }, [rectSize, svgRef, space, leftPad]);\n\n  const initStartDate = useMemo(() => {\n    if (isValidDate(startDate)) {\n      return !startDate.getDay() ? startDate : new Date(startDate.getTime() - startDate.getDay() * oneDayTime);\n    } else {\n      const newDate = new Date();\n      return new Date(newDate.getTime() - newDate.getDay() * oneDayTime);\n    }\n  }, [startDate]);\n\n  return (\n    <svg ref={svgRef} {...other}>\n      <WeekLables weekLables={weekLables} rectSize={rectSize} space={space} />\n      <g transform={`translate(${leftPad}, 20)`}>\n        {[...Array(gridNum)].map((_, idx) => {\n          return (\n            <g key={idx} data-column={idx}>\n              {[...Array(7)].map((_, cidx) => {\n                const dayProps: RectDayElement = {\n                  ...rectProps,\n                  rectSize,\n                  space,\n                  key: cidx,\n                  row: cidx,\n                  column: idx,\n                  fill: '#EBEDF0',\n                };\n                const currentDate = new Date(initStartDate.getTime() + oneDayTime * (idx * 7 + cidx));\n                dayProps.date = getDateToString(currentDate);\n                if (endDate instanceof Date && currentDate.getTime() > endDate.getTime()) {\n                  return null;\n                }\n                if (dayProps.date && data[dayProps.date] && panelColors && Object.keys(panelColors).length > 0) {\n                  dayProps.fill = existColor(data[dayProps.date].count || 0, nums, panelColors);\n                } else if (panelColors && panelColors[0]) {\n                  dayProps.fill = panelColors[0];\n                }\n                if (renderRect && typeof renderRect === 'function') {\n                  const elm = renderRect(dayProps);\n                  if (elm && React.isValidElement(elm)) {\n                    return elm;\n                  }\n                }\n                return <RectDay {...dayProps} />;\n              })}\n            </g>\n          );\n        })}\n      </g>\n    </svg>\n  );\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/SVG.tsx"],"names":["SVG","props","rectSize","legendCellSize","space","startDate","Date","endDate","rectProps","renderRect","value","weekLables","monthLables","panelColors","other","gridNum","setGridNum","leftPad","setLeftPad","topPad","setTopPad","svgRef","React","createRef","nums","Object","keys","map","item","parseInt","data","current","width","clientWidth","Math","floor","initStartDate","getDay","getTime","oneDayTime","newDate","Array","_","idx","cidx","dayProps","key","row","column","fill","currentDate","date","length","count","elm","isValidElement"],"mappings":"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","sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport { LablesWeek } from './LablesWeek';\nimport { LablesMonth } from './LablesMonth';\nimport { RectDay, RectDayDefaultProps } from './RectDay';\nimport { formatData, getDateToString, existColor, numberSort, isValidDate, oneDayTime } from './utils';\nimport Legend from './Legend';\n\nexport type HeatMapValue = {\n  date: string;\n  content: string | string[] | React.ReactNode;\n  count: number;\n};\n\nexport type RectDayElement<T = SVGRectElement> = RectDayDefaultProps & React.SVGProps<T>;\n\nexport interface SVGProps extends React.SVGProps<SVGSVGElement> {\n  startDate?: Date;\n  endDate?: Date;\n  rectSize?: number;\n  legendCellSize?: number;\n  space?: number;\n  rectProps?: RectDayElement | RectDayDefaultProps;\n  renderRect?: <E = SVGRectElement>(\n    data: E & RectDayDefaultProps & { fill?: string },\n    valueItem?: HeatMapValue,\n  ) => React.ReactElement | void;\n  value?: Array<HeatMapValue>;\n  weekLables?: string[] | false;\n  monthLables?: string[] | false;\n  panelColors?: Record<number, string>;\n}\n\nexport default function SVG(props: SVGProps) {\n  const {\n    rectSize = 11,\n    legendCellSize = 11,\n    space = 2,\n    startDate = new Date(),\n    endDate,\n    rectProps,\n    renderRect,\n    value = [],\n    weekLables = ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n    monthLables = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n    panelColors = { 0: '#EBEDF0', 8: '#7BC96F', 4: '#C6E48B', 12: '#239A3B', 32: '#196127' },\n    ...other\n  } = props || {};\n  const [gridNum, setGridNum] = useState(0);\n  const [leftPad, setLeftPad] = useState(!!weekLables ? 28 : 5);\n  const [topPad, setTopPad] = useState(!!monthLables ? 20 : 5);\n  const svgRef = React.createRef<SVGSVGElement>();\n  const nums = useMemo(() => numberSort(Object.keys(panelColors).map((item) => parseInt(item, 10))), [panelColors]);\n  const data = useMemo(() => formatData(value), [value]);\n  useEffect(() => setLeftPad(!!weekLables ? 28 : 5), [weekLables]);\n  useEffect(() => {\n    if (svgRef.current) {\n      const width = svgRef.current.clientWidth - leftPad || 0;\n      setGridNum(Math.floor(width / (rectSize + space)) || 0);\n    }\n  }, [rectSize, svgRef, space, leftPad]);\n\n  useEffect(() => {\n    setTopPad(!!monthLables ? 20 : 5);\n  }, [monthLables]);\n\n  const initStartDate = useMemo(() => {\n    if (isValidDate(startDate)) {\n      return !startDate.getDay() ? startDate : new Date(startDate.getTime() - startDate.getDay() * oneDayTime);\n    } else {\n      const newDate = new Date();\n      return new Date(newDate.getTime() - newDate.getDay() * oneDayTime);\n    }\n  }, [startDate]);\n\n  return (\n    <svg ref={svgRef} {...other}>\n      {legendCellSize !== 0 && (\n        <Legend\n          panelColors={panelColors}\n          rectSize={rectSize}\n          legendCellSize={legendCellSize}\n          leftPad={leftPad}\n          topPad={topPad}\n          space={space}\n        />\n      )}\n      <LablesWeek weekLables={weekLables} rectSize={rectSize} space={space} topPad={topPad} />\n      <LablesMonth\n        monthLables={monthLables}\n        rectSize={rectSize}\n        space={space}\n        leftPad={leftPad}\n        colNum={gridNum}\n        startDate={initStartDate}\n      />\n      <g transform={`translate(${leftPad}, ${topPad})`}>\n        {[...Array(gridNum)].map((_, idx) => {\n          return (\n            <g key={idx} data-column={idx}>\n              {[...Array(7)].map((_, cidx) => {\n                const dayProps: RectDayElement = {\n                  ...rectProps,\n                  rectSize,\n                  space,\n                  key: cidx,\n                  row: cidx,\n                  column: idx,\n                  fill: '#EBEDF0',\n                };\n                const currentDate = new Date(initStartDate.getTime() + oneDayTime * (idx * 7 + cidx));\n                dayProps.date = getDateToString(currentDate);\n                if (endDate instanceof Date && currentDate.getTime() > endDate.getTime()) {\n                  return null;\n                }\n                if (dayProps.date && data[dayProps.date] && panelColors && Object.keys(panelColors).length > 0) {\n                  dayProps.fill = existColor(data[dayProps.date].count || 0, nums, panelColors);\n                } else if (panelColors && panelColors[0]) {\n                  dayProps.fill = panelColors[0];\n                }\n                if (renderRect && typeof renderRect === 'function') {\n                  const elm = renderRect(dayProps, data[dayProps.date]);\n                  if (elm && React.isValidElement(elm)) {\n                    return elm;\n                  }\n                }\n                return <RectDay {...dayProps} />;\n              })}\n            </g>\n          );\n        })}\n      </g>\n    </svg>\n  );\n}\n"]}
import { SVGProps, HeatMapValue } from './SVG';
export declare const oneDayTime: number;
export declare function isValidDate(date: Date): boolean;

@@ -3,0 +4,0 @@ export declare function getDateToString(date: Date): string;

@@ -11,2 +11,5 @@ "use strict";

exports.existColor = existColor;
exports.oneDayTime = void 0;
var oneDayTime = 24 * 60 * 60 * 1000;
exports.oneDayTime = oneDayTime;

@@ -60,2 +63,2 @@ function isValidDate(date) {

}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy50cyJdLCJuYW1lcyI6WyJpc1ZhbGlkRGF0ZSIsImRhdGUiLCJEYXRlIiwiaXNOYU4iLCJnZXRUaW1lIiwiZ2V0RGF0ZVRvU3RyaW5nIiwiZ2V0RnVsbFllYXIiLCJnZXRNb250aCIsImdldERhdGUiLCJmb3JtYXREYXRhIiwiZGF0YSIsInJlc3VsdCIsImZvckVhY2giLCJpdGVtIiwibnVtYmVyU29ydCIsImtleXMiLCJzb3J0IiwieCIsInkiLCJleGlzdENvbG9yIiwibnVtIiwibnVtcyIsInBhbmVsQ29sb3JzIiwiY29sb3IiLCJhIiwibGVuZ3RoIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUVPLFNBQVNBLFdBQVQsQ0FBcUJDLElBQXJCLEVBQWlDO0FBQ3RDLFNBQU9BLElBQUksWUFBWUMsSUFBaEIsSUFBd0IsQ0FBQ0MsS0FBSyxDQUFDRixJQUFJLENBQUNHLE9BQUwsRUFBRCxDQUFyQztBQUNEOztBQUVNLFNBQVNDLGVBQVQsQ0FBeUJKLElBQXpCLEVBQXFDO0FBQzFDLG1CQUFVQSxJQUFJLENBQUNLLFdBQUwsRUFBVixjQUFnQ0wsSUFBSSxDQUFDTSxRQUFMLEtBQWtCLENBQWxELGNBQXVETixJQUFJLENBQUNPLE9BQUwsRUFBdkQ7QUFDRDs7QUFFTSxTQUFTQyxVQUFULEdBQWtEO0FBQUEsTUFBOUJDLElBQThCLHVFQUFKLEVBQUk7QUFDdkQsTUFBTUMsTUFBb0MsR0FBRyxFQUE3QztBQUNBRCxFQUFBQSxJQUFJLENBQUNFLE9BQUwsQ0FBYSxVQUFDQyxJQUFELEVBQVU7QUFDckIsUUFBSUEsSUFBSSxDQUFDWixJQUFMLElBQWFELFdBQVcsQ0FBQyxJQUFJRSxJQUFKLENBQVNXLElBQUksQ0FBQ1osSUFBZCxDQUFELENBQTVCLEVBQW1EO0FBQ2pEWSxNQUFBQSxJQUFJLENBQUNaLElBQUwsR0FBWUksZUFBZSxDQUFDLElBQUlILElBQUosQ0FBU1csSUFBSSxDQUFDWixJQUFkLENBQUQsQ0FBM0I7QUFDQVUsTUFBQUEsTUFBTSxDQUFDRSxJQUFJLENBQUNaLElBQU4sQ0FBTixHQUFvQlksSUFBcEI7QUFDRDtBQUNGLEdBTEQ7QUFNQSxTQUFPRixNQUFQO0FBQ0Q7QUFFRDs7O0FBQ08sU0FBU0csVUFBVCxHQUF5QztBQUFBLE1BQXJCQyxJQUFxQix1RUFBSixFQUFJO0FBQzlDLFNBQU9BLElBQUksQ0FBQ0MsSUFBTCxDQUFVLFVBQUNDLENBQUQsRUFBSUMsQ0FBSixFQUFVO0FBQ3pCLFFBQUlELENBQUMsR0FBR0MsQ0FBUixFQUFXLE9BQU8sQ0FBQyxDQUFSLENBQVgsS0FDSyxJQUFJRCxDQUFDLEdBQUdDLENBQVIsRUFBVyxPQUFPLENBQVA7QUFDaEIsV0FBTyxDQUFQO0FBQ0QsR0FKTSxDQUFQO0FBS0Q7O0FBRU0sU0FBU0MsVUFBVCxHQUErRjtBQUFBLE1BQTNFQyxHQUEyRSx1RUFBN0QsQ0FBNkQ7QUFBQSxNQUExREMsSUFBMEQ7QUFBQSxNQUExQ0MsV0FBMEMsdUVBQUosRUFBSTtBQUNwRyxNQUFJQyxLQUFLLEdBQUcsRUFBWjs7QUFDQSxPQUFLLElBQUlDLENBQUMsR0FBRyxDQUFiLEVBQWdCQSxDQUFDLEdBQUdILElBQUksQ0FBQ0ksTUFBekIsRUFBaUNELENBQUMsSUFBSSxDQUF0QyxFQUF5QztBQUN2QyxRQUFJSCxJQUFJLENBQUNHLENBQUQsQ0FBSixHQUFVSixHQUFkLEVBQW1CO0FBQ2pCRyxNQUFBQSxLQUFLLEdBQUdELFdBQVcsQ0FBQ0QsSUFBSSxDQUFDRyxDQUFELENBQUwsQ0FBbkI7QUFDQTtBQUNEOztBQUNERCxJQUFBQSxLQUFLLEdBQUdELFdBQVcsQ0FBQ0QsSUFBSSxDQUFDRyxDQUFELENBQUwsQ0FBbkI7QUFDRDs7QUFDRCxTQUFPRCxLQUFQO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTVkdQcm9wcywgSGVhdE1hcFZhbHVlIH0gZnJvbSAnLi9TVkcnO1xuXG5leHBvcnQgZnVuY3Rpb24gaXNWYWxpZERhdGUoZGF0ZTogRGF0ZSkge1xuICByZXR1cm4gZGF0ZSBpbnN0YW5jZW9mIERhdGUgJiYgIWlzTmFOKGRhdGUuZ2V0VGltZSgpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldERhdGVUb1N0cmluZyhkYXRlOiBEYXRlKSB7XG4gIHJldHVybiBgJHtkYXRlLmdldEZ1bGxZZWFyKCl9LyR7ZGF0ZS5nZXRNb250aCgpICsgMX0vJHtkYXRlLmdldERhdGUoKX1gO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZm9ybWF0RGF0YShkYXRhOiBTVkdQcm9wc1sndmFsdWUnXSA9IFtdKSB7XG4gIGNvbnN0IHJlc3VsdDogUmVjb3JkPHN0cmluZywgSGVhdE1hcFZhbHVlPiA9IHt9O1xuICBkYXRhLmZvckVhY2goKGl0ZW0pID0+IHtcbiAgICBpZiAoaXRlbS5kYXRlICYmIGlzVmFsaWREYXRlKG5ldyBEYXRlKGl0ZW0uZGF0ZSkpKSB7XG4gICAgICBpdGVtLmRhdGUgPSBnZXREYXRlVG9TdHJpbmcobmV3IERhdGUoaXRlbS5kYXRlKSk7XG4gICAgICByZXN1bHRbaXRlbS5kYXRlXSA9IGl0ZW07XG4gICAgfVxuICB9KTtcbiAgcmV0dXJuIHJlc3VsdDtcbn1cblxuLyoqIOaOkuW6jyDmr5TovoPlh73mlbAgKi9cbmV4cG9ydCBmdW5jdGlvbiBudW1iZXJTb3J0KGtleXM6IG51bWJlcltdID0gW10pIHtcbiAgcmV0dXJuIGtleXMuc29ydCgoeCwgeSkgPT4ge1xuICAgIGlmICh4IDwgeSkgcmV0dXJuIC0xO1xuICAgIGVsc2UgaWYgKHggPiB5KSByZXR1cm4gMTtcbiAgICByZXR1cm4gMDtcbiAgfSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBleGlzdENvbG9yKG51bTogbnVtYmVyID0gMCwgbnVtczogbnVtYmVyW10sIHBhbmVsQ29sb3JzOiBSZWNvcmQ8bnVtYmVyLCBzdHJpbmc+ID0ge30pIHtcbiAgbGV0IGNvbG9yID0gJyc7XG4gIGZvciAobGV0IGEgPSAwOyBhIDwgbnVtcy5sZW5ndGg7IGEgKz0gMSkge1xuICAgIGlmIChudW1zW2FdID4gbnVtKSB7XG4gICAgICBjb2xvciA9IHBhbmVsQ29sb3JzW251bXNbYV1dO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGNvbG9yID0gcGFuZWxDb2xvcnNbbnVtc1thXV07XG4gIH1cbiAgcmV0dXJuIGNvbG9yO1xufVxuIl19
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy50cyJdLCJuYW1lcyI6WyJvbmVEYXlUaW1lIiwiaXNWYWxpZERhdGUiLCJkYXRlIiwiRGF0ZSIsImlzTmFOIiwiZ2V0VGltZSIsImdldERhdGVUb1N0cmluZyIsImdldEZ1bGxZZWFyIiwiZ2V0TW9udGgiLCJnZXREYXRlIiwiZm9ybWF0RGF0YSIsImRhdGEiLCJyZXN1bHQiLCJmb3JFYWNoIiwiaXRlbSIsIm51bWJlclNvcnQiLCJrZXlzIiwic29ydCIsIngiLCJ5IiwiZXhpc3RDb2xvciIsIm51bSIsIm51bXMiLCJwYW5lbENvbG9ycyIsImNvbG9yIiwiYSIsImxlbmd0aCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFFTyxJQUFNQSxVQUFVLEdBQUcsS0FBSyxFQUFMLEdBQVUsRUFBVixHQUFlLElBQWxDOzs7QUFFQSxTQUFTQyxXQUFULENBQXFCQyxJQUFyQixFQUFpQztBQUN0QyxTQUFPQSxJQUFJLFlBQVlDLElBQWhCLElBQXdCLENBQUNDLEtBQUssQ0FBQ0YsSUFBSSxDQUFDRyxPQUFMLEVBQUQsQ0FBckM7QUFDRDs7QUFFTSxTQUFTQyxlQUFULENBQXlCSixJQUF6QixFQUFxQztBQUMxQyxtQkFBVUEsSUFBSSxDQUFDSyxXQUFMLEVBQVYsY0FBZ0NMLElBQUksQ0FBQ00sUUFBTCxLQUFrQixDQUFsRCxjQUF1RE4sSUFBSSxDQUFDTyxPQUFMLEVBQXZEO0FBQ0Q7O0FBRU0sU0FBU0MsVUFBVCxHQUFrRDtBQUFBLE1BQTlCQyxJQUE4Qix1RUFBSixFQUFJO0FBQ3ZELE1BQU1DLE1BQW9DLEdBQUcsRUFBN0M7QUFDQUQsRUFBQUEsSUFBSSxDQUFDRSxPQUFMLENBQWEsVUFBQ0MsSUFBRCxFQUFVO0FBQ3JCLFFBQUlBLElBQUksQ0FBQ1osSUFBTCxJQUFhRCxXQUFXLENBQUMsSUFBSUUsSUFBSixDQUFTVyxJQUFJLENBQUNaLElBQWQsQ0FBRCxDQUE1QixFQUFtRDtBQUNqRFksTUFBQUEsSUFBSSxDQUFDWixJQUFMLEdBQVlJLGVBQWUsQ0FBQyxJQUFJSCxJQUFKLENBQVNXLElBQUksQ0FBQ1osSUFBZCxDQUFELENBQTNCO0FBQ0FVLE1BQUFBLE1BQU0sQ0FBQ0UsSUFBSSxDQUFDWixJQUFOLENBQU4sR0FBb0JZLElBQXBCO0FBQ0Q7QUFDRixHQUxEO0FBTUEsU0FBT0YsTUFBUDtBQUNEO0FBRUQ7OztBQUNPLFNBQVNHLFVBQVQsR0FBeUM7QUFBQSxNQUFyQkMsSUFBcUIsdUVBQUosRUFBSTtBQUM5QyxTQUFPQSxJQUFJLENBQUNDLElBQUwsQ0FBVSxVQUFDQyxDQUFELEVBQUlDLENBQUosRUFBVTtBQUN6QixRQUFJRCxDQUFDLEdBQUdDLENBQVIsRUFBVyxPQUFPLENBQUMsQ0FBUixDQUFYLEtBQ0ssSUFBSUQsQ0FBQyxHQUFHQyxDQUFSLEVBQVcsT0FBTyxDQUFQO0FBQ2hCLFdBQU8sQ0FBUDtBQUNELEdBSk0sQ0FBUDtBQUtEOztBQUVNLFNBQVNDLFVBQVQsR0FBK0Y7QUFBQSxNQUEzRUMsR0FBMkUsdUVBQTdELENBQTZEO0FBQUEsTUFBMURDLElBQTBEO0FBQUEsTUFBMUNDLFdBQTBDLHVFQUFKLEVBQUk7QUFDcEcsTUFBSUMsS0FBSyxHQUFHLEVBQVo7O0FBQ0EsT0FBSyxJQUFJQyxDQUFDLEdBQUcsQ0FBYixFQUFnQkEsQ0FBQyxHQUFHSCxJQUFJLENBQUNJLE1BQXpCLEVBQWlDRCxDQUFDLElBQUksQ0FBdEMsRUFBeUM7QUFDdkMsUUFBSUgsSUFBSSxDQUFDRyxDQUFELENBQUosR0FBVUosR0FBZCxFQUFtQjtBQUNqQkcsTUFBQUEsS0FBSyxHQUFHRCxXQUFXLENBQUNELElBQUksQ0FBQ0csQ0FBRCxDQUFMLENBQW5CO0FBQ0E7QUFDRDs7QUFDREQsSUFBQUEsS0FBSyxHQUFHRCxXQUFXLENBQUNELElBQUksQ0FBQ0csQ0FBRCxDQUFMLENBQW5CO0FBQ0Q7O0FBQ0QsU0FBT0QsS0FBUDtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU1ZHUHJvcHMsIEhlYXRNYXBWYWx1ZSB9IGZyb20gJy4vU1ZHJztcblxuZXhwb3J0IGNvbnN0IG9uZURheVRpbWUgPSAyNCAqIDYwICogNjAgKiAxMDAwO1xuXG5leHBvcnQgZnVuY3Rpb24gaXNWYWxpZERhdGUoZGF0ZTogRGF0ZSkge1xuICByZXR1cm4gZGF0ZSBpbnN0YW5jZW9mIERhdGUgJiYgIWlzTmFOKGRhdGUuZ2V0VGltZSgpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldERhdGVUb1N0cmluZyhkYXRlOiBEYXRlKSB7XG4gIHJldHVybiBgJHtkYXRlLmdldEZ1bGxZZWFyKCl9LyR7ZGF0ZS5nZXRNb250aCgpICsgMX0vJHtkYXRlLmdldERhdGUoKX1gO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZm9ybWF0RGF0YShkYXRhOiBTVkdQcm9wc1sndmFsdWUnXSA9IFtdKSB7XG4gIGNvbnN0IHJlc3VsdDogUmVjb3JkPHN0cmluZywgSGVhdE1hcFZhbHVlPiA9IHt9O1xuICBkYXRhLmZvckVhY2goKGl0ZW0pID0+IHtcbiAgICBpZiAoaXRlbS5kYXRlICYmIGlzVmFsaWREYXRlKG5ldyBEYXRlKGl0ZW0uZGF0ZSkpKSB7XG4gICAgICBpdGVtLmRhdGUgPSBnZXREYXRlVG9TdHJpbmcobmV3IERhdGUoaXRlbS5kYXRlKSk7XG4gICAgICByZXN1bHRbaXRlbS5kYXRlXSA9IGl0ZW07XG4gICAgfVxuICB9KTtcbiAgcmV0dXJuIHJlc3VsdDtcbn1cblxuLyoqIOaOkuW6jyDmr5TovoPlh73mlbAgKi9cbmV4cG9ydCBmdW5jdGlvbiBudW1iZXJTb3J0KGtleXM6IG51bWJlcltdID0gW10pIHtcbiAgcmV0dXJuIGtleXMuc29ydCgoeCwgeSkgPT4ge1xuICAgIGlmICh4IDwgeSkgcmV0dXJuIC0xO1xuICAgIGVsc2UgaWYgKHggPiB5KSByZXR1cm4gMTtcbiAgICByZXR1cm4gMDtcbiAgfSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBleGlzdENvbG9yKG51bTogbnVtYmVyID0gMCwgbnVtczogbnVtYmVyW10sIHBhbmVsQ29sb3JzOiBSZWNvcmQ8bnVtYmVyLCBzdHJpbmc+ID0ge30pIHtcbiAgbGV0IGNvbG9yID0gJyc7XG4gIGZvciAobGV0IGEgPSAwOyBhIDwgbnVtcy5sZW5ndGg7IGEgKz0gMSkge1xuICAgIGlmIChudW1zW2FdID4gbnVtKSB7XG4gICAgICBjb2xvciA9IHBhbmVsQ29sb3JzW251bXNbYV1dO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGNvbG9yID0gcGFuZWxDb2xvcnNbbnVtc1thXV07XG4gIH1cbiAgcmV0dXJuIGNvbG9yO1xufVxuIl19

@@ -1,9 +0,5 @@

import _extends from "@babel/runtime/helpers/extends";
import React from 'react';
export var Rect = function Rect(props) {
return /*#__PURE__*/React.createElement("rect", _extends({}, props, {
rx: "2",
ry: "2"
}));
return /*#__PURE__*/React.createElement("rect", props);
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9SZWN0LnRzeCJdLCJuYW1lcyI6WyJSZWFjdCIsIlJlY3QiLCJwcm9wcyJdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU9BLEtBQVAsTUFBa0IsT0FBbEI7QUFHQSxPQUFPLElBQU1DLElBQUksR0FBRyxTQUFQQSxJQUFPLENBQUNDLEtBQUQ7QUFBQSxzQkFBc0IseUNBQVVBLEtBQVY7QUFBaUIsSUFBQSxFQUFFLEVBQUMsR0FBcEI7QUFBd0IsSUFBQSxFQUFFLEVBQUM7QUFBM0IsS0FBdEI7QUFBQSxDQUFiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuZXhwb3J0IGludGVyZmFjZSBSZWN0UHJvcHMgZXh0ZW5kcyBSZWFjdC5TVkdQcm9wczxTVkdSZWN0RWxlbWVudD4ge31cbmV4cG9ydCBjb25zdCBSZWN0ID0gKHByb3BzOiBSZWN0UHJvcHMpID0+IDxyZWN0IHsuLi5wcm9wc30gcng9XCIyXCIgcnk9XCIyXCIgLz47XG4iXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9SZWN0LnRzeCJdLCJuYW1lcyI6WyJSZWFjdCIsIlJlY3QiLCJwcm9wcyJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsS0FBUCxNQUFrQixPQUFsQjtBQUdBLE9BQU8sSUFBTUMsSUFBSSxHQUFHLFNBQVBBLElBQU8sQ0FBQ0MsS0FBRDtBQUFBLHNCQUFzQiw0QkFBVUEsS0FBVixDQUF0QjtBQUFBLENBQWIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFJlY3RQcm9wcyBleHRlbmRzIFJlYWN0LlNWR1Byb3BzPFNWR1JlY3RFbGVtZW50PiB7fVxuZXhwb3J0IGNvbnN0IFJlY3QgPSAocHJvcHM6IFJlY3RQcm9wcykgPT4gPHJlY3Qgey4uLnByb3BzfSAvPjtcbiJdfQ==

@@ -13,2 +13,3 @@ import React from 'react';

rectSize?: number;
legendCellSize?: number;
space?: number;

@@ -18,8 +19,8 @@ rectProps?: RectDayElement | RectDayDefaultProps;

fill?: string;
}) => React.ReactElement | void;
}, valueItem?: HeatMapValue) => React.ReactElement | void;
value?: Array<HeatMapValue>;
weekLables?: string[] | false;
monthLables?: string[];
monthLables?: string[] | false;
panelColors?: Record<number, string>;
}
export default function SVG(props: SVGProps): JSX.Element;

@@ -7,6 +7,7 @@ import _extends from "@babel/runtime/helpers/extends";

import React, { useEffect, useMemo, useState } from 'react';
import { WeekLables } from './WeekLables';
import { LablesWeek } from './LablesWeek';
import { LablesMonth } from './LablesMonth';
import { RectDay } from './RectDay';
import { formatData, getDateToString, existColor, numberSort, isValidDate } from './utils';
var oneDayTime = 24 * 60 * 60 * 1000;
import { formatData, getDateToString, existColor, numberSort, isValidDate, oneDayTime } from './utils';
import Legend from './Legend';
export default function SVG(props) {

@@ -16,2 +17,4 @@ var _ref = props || {},

rectSize = _ref$rectSize === void 0 ? 11 : _ref$rectSize,
_ref$legendCellSize = _ref.legendCellSize,
legendCellSize = _ref$legendCellSize === void 0 ? 11 : _ref$legendCellSize,
_ref$space = _ref.space,

@@ -38,3 +41,3 @@ space = _ref$space === void 0 ? 2 : _ref$space,

} : _ref$panelColors,
other = _objectWithoutProperties(_ref, ["rectSize", "space", "startDate", "endDate", "rectProps", "renderRect", "value", "weekLables", "monthLables", "panelColors"]);
other = _objectWithoutProperties(_ref, ["rectSize", "legendCellSize", "space", "startDate", "endDate", "rectProps", "renderRect", "value", "weekLables", "monthLables", "panelColors"]);

@@ -51,2 +54,7 @@ var _useState = useState(0),

var _useState5 = useState(!!monthLables ? 20 : 5),
_useState6 = _slicedToArray(_useState5, 2),
topPad = _useState6[0],
setTopPad = _useState6[1];
var svgRef = /*#__PURE__*/React.createRef();

@@ -70,2 +78,5 @@ var nums = useMemo(function () {

}, [rectSize, svgRef, space, leftPad]);
useEffect(function () {
setTopPad(!!monthLables ? 20 : 5);
}, [monthLables]);
var initStartDate = useMemo(function () {

@@ -81,8 +92,23 @@ if (isValidDate(startDate)) {

ref: svgRef
}, other), /*#__PURE__*/React.createElement(WeekLables, {
}, other), legendCellSize !== 0 && /*#__PURE__*/React.createElement(Legend, {
panelColors: panelColors,
rectSize: rectSize,
legendCellSize: legendCellSize,
leftPad: leftPad,
topPad: topPad,
space: space
}), /*#__PURE__*/React.createElement(LablesWeek, {
weekLables: weekLables,
rectSize: rectSize,
space: space
space: space,
topPad: topPad
}), /*#__PURE__*/React.createElement(LablesMonth, {
monthLables: monthLables,
rectSize: rectSize,
space: space,
leftPad: leftPad,
colNum: gridNum,
startDate: initStartDate
}), /*#__PURE__*/React.createElement("g", {
transform: "translate(".concat(leftPad, ", 20)")
transform: "translate(".concat(leftPad, ", ").concat(topPad, ")")
}, _toConsumableArray(Array(gridNum)).map(function (_, idx) {

@@ -116,3 +142,3 @@ return /*#__PURE__*/React.createElement("g", {

if (renderRect && typeof renderRect === 'function') {
var elm = renderRect(dayProps);
var elm = renderRect(dayProps, data[dayProps.date]);

@@ -128,2 +154,2 @@ if (elm && /*#__PURE__*/React.isValidElement(elm)) {

}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/SVG.tsx"],"names":["React","useEffect","useMemo","useState","WeekLables","RectDay","formatData","getDateToString","existColor","numberSort","isValidDate","oneDayTime","SVG","props","rectSize","space","startDate","Date","endDate","rectProps","renderRect","value","weekLables","monthLables","panelColors","other","gridNum","setGridNum","leftPad","setLeftPad","svgRef","createRef","nums","Object","keys","map","item","parseInt","data","current","width","clientWidth","Math","floor","initStartDate","getDay","getTime","newDate","Array","_","idx","cidx","dayProps","key","row","column","fill","currentDate","date","length","count","elm","isValidElement"],"mappings":"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","sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport { WeekLables } from './WeekLables';\nimport { RectDay, RectDayDefaultProps } from './RectDay';\nimport { formatData, getDateToString, existColor, numberSort, isValidDate } from './utils';\n\nconst oneDayTime = 24 * 60 * 60 * 1000;\n\nexport type HeatMapValue = {\n  date: string;\n  content: string | string[] | React.ReactNode;\n  count: number;\n};\n\nexport type RectDayElement<T = SVGRectElement> = RectDayDefaultProps & React.SVGProps<T>;\n\nexport interface SVGProps extends React.SVGProps<SVGSVGElement> {\n  startDate?: Date;\n  endDate?: Date;\n  rectSize?: number;\n  space?: number;\n  rectProps?: RectDayElement | RectDayDefaultProps;\n  renderRect?: <E = SVGRectElement>(data: E & RectDayDefaultProps & { fill?: string }) => React.ReactElement | void;\n  value?: Array<HeatMapValue>;\n  weekLables?: string[] | false;\n  monthLables?: string[];\n  panelColors?: Record<number, string>;\n}\n\nexport default function SVG(props: SVGProps) {\n  const {\n    rectSize = 11,\n    space = 2,\n    startDate = new Date(),\n    endDate,\n    rectProps,\n    renderRect,\n    value = [],\n    weekLables = ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n    monthLables = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n    panelColors = { 0: '#EBEDF0', 8: '#7BC96F', 4: '#C6E48B', 12: '#239A3B', 32: '#196127' },\n    ...other\n  } = props || {};\n  const [gridNum, setGridNum] = useState(0);\n  const [leftPad, setLeftPad] = useState(!!weekLables ? 28 : 5);\n  const svgRef = React.createRef<SVGSVGElement>();\n  const nums = useMemo(() => numberSort(Object.keys(panelColors).map((item) => parseInt(item, 10))), [panelColors]);\n  const data = useMemo(() => formatData(value), [value]);\n  useEffect(() => setLeftPad(!!weekLables ? 28 : 5), [weekLables]);\n  useEffect(() => {\n    if (svgRef.current) {\n      const width = svgRef.current.clientWidth - leftPad || 0;\n      setGridNum(Math.floor(width / (rectSize + space)) || 0);\n    }\n  }, [rectSize, svgRef, space, leftPad]);\n\n  const initStartDate = useMemo(() => {\n    if (isValidDate(startDate)) {\n      return !startDate.getDay() ? startDate : new Date(startDate.getTime() - startDate.getDay() * oneDayTime);\n    } else {\n      const newDate = new Date();\n      return new Date(newDate.getTime() - newDate.getDay() * oneDayTime);\n    }\n  }, [startDate]);\n\n  return (\n    <svg ref={svgRef} {...other}>\n      <WeekLables weekLables={weekLables} rectSize={rectSize} space={space} />\n      <g transform={`translate(${leftPad}, 20)`}>\n        {[...Array(gridNum)].map((_, idx) => {\n          return (\n            <g key={idx} data-column={idx}>\n              {[...Array(7)].map((_, cidx) => {\n                const dayProps: RectDayElement = {\n                  ...rectProps,\n                  rectSize,\n                  space,\n                  key: cidx,\n                  row: cidx,\n                  column: idx,\n                  fill: '#EBEDF0',\n                };\n                const currentDate = new Date(initStartDate.getTime() + oneDayTime * (idx * 7 + cidx));\n                dayProps.date = getDateToString(currentDate);\n                if (endDate instanceof Date && currentDate.getTime() > endDate.getTime()) {\n                  return null;\n                }\n                if (dayProps.date && data[dayProps.date] && panelColors && Object.keys(panelColors).length > 0) {\n                  dayProps.fill = existColor(data[dayProps.date].count || 0, nums, panelColors);\n                } else if (panelColors && panelColors[0]) {\n                  dayProps.fill = panelColors[0];\n                }\n                if (renderRect && typeof renderRect === 'function') {\n                  const elm = renderRect(dayProps);\n                  if (elm && React.isValidElement(elm)) {\n                    return elm;\n                  }\n                }\n                return <RectDay {...dayProps} />;\n              })}\n            </g>\n          );\n        })}\n      </g>\n    </svg>\n  );\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/SVG.tsx"],"names":["React","useEffect","useMemo","useState","LablesWeek","LablesMonth","RectDay","formatData","getDateToString","existColor","numberSort","isValidDate","oneDayTime","Legend","SVG","props","rectSize","legendCellSize","space","startDate","Date","endDate","rectProps","renderRect","value","weekLables","monthLables","panelColors","other","gridNum","setGridNum","leftPad","setLeftPad","topPad","setTopPad","svgRef","createRef","nums","Object","keys","map","item","parseInt","data","current","width","clientWidth","Math","floor","initStartDate","getDay","getTime","newDate","Array","_","idx","cidx","dayProps","key","row","column","fill","currentDate","date","length","count","elm","isValidElement"],"mappings":"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","sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport { LablesWeek } from './LablesWeek';\nimport { LablesMonth } from './LablesMonth';\nimport { RectDay, RectDayDefaultProps } from './RectDay';\nimport { formatData, getDateToString, existColor, numberSort, isValidDate, oneDayTime } from './utils';\nimport Legend from './Legend';\n\nexport type HeatMapValue = {\n  date: string;\n  content: string | string[] | React.ReactNode;\n  count: number;\n};\n\nexport type RectDayElement<T = SVGRectElement> = RectDayDefaultProps & React.SVGProps<T>;\n\nexport interface SVGProps extends React.SVGProps<SVGSVGElement> {\n  startDate?: Date;\n  endDate?: Date;\n  rectSize?: number;\n  legendCellSize?: number;\n  space?: number;\n  rectProps?: RectDayElement | RectDayDefaultProps;\n  renderRect?: <E = SVGRectElement>(\n    data: E & RectDayDefaultProps & { fill?: string },\n    valueItem?: HeatMapValue,\n  ) => React.ReactElement | void;\n  value?: Array<HeatMapValue>;\n  weekLables?: string[] | false;\n  monthLables?: string[] | false;\n  panelColors?: Record<number, string>;\n}\n\nexport default function SVG(props: SVGProps) {\n  const {\n    rectSize = 11,\n    legendCellSize = 11,\n    space = 2,\n    startDate = new Date(),\n    endDate,\n    rectProps,\n    renderRect,\n    value = [],\n    weekLables = ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n    monthLables = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n    panelColors = { 0: '#EBEDF0', 8: '#7BC96F', 4: '#C6E48B', 12: '#239A3B', 32: '#196127' },\n    ...other\n  } = props || {};\n  const [gridNum, setGridNum] = useState(0);\n  const [leftPad, setLeftPad] = useState(!!weekLables ? 28 : 5);\n  const [topPad, setTopPad] = useState(!!monthLables ? 20 : 5);\n  const svgRef = React.createRef<SVGSVGElement>();\n  const nums = useMemo(() => numberSort(Object.keys(panelColors).map((item) => parseInt(item, 10))), [panelColors]);\n  const data = useMemo(() => formatData(value), [value]);\n  useEffect(() => setLeftPad(!!weekLables ? 28 : 5), [weekLables]);\n  useEffect(() => {\n    if (svgRef.current) {\n      const width = svgRef.current.clientWidth - leftPad || 0;\n      setGridNum(Math.floor(width / (rectSize + space)) || 0);\n    }\n  }, [rectSize, svgRef, space, leftPad]);\n\n  useEffect(() => {\n    setTopPad(!!monthLables ? 20 : 5);\n  }, [monthLables]);\n\n  const initStartDate = useMemo(() => {\n    if (isValidDate(startDate)) {\n      return !startDate.getDay() ? startDate : new Date(startDate.getTime() - startDate.getDay() * oneDayTime);\n    } else {\n      const newDate = new Date();\n      return new Date(newDate.getTime() - newDate.getDay() * oneDayTime);\n    }\n  }, [startDate]);\n\n  return (\n    <svg ref={svgRef} {...other}>\n      {legendCellSize !== 0 && (\n        <Legend\n          panelColors={panelColors}\n          rectSize={rectSize}\n          legendCellSize={legendCellSize}\n          leftPad={leftPad}\n          topPad={topPad}\n          space={space}\n        />\n      )}\n      <LablesWeek weekLables={weekLables} rectSize={rectSize} space={space} topPad={topPad} />\n      <LablesMonth\n        monthLables={monthLables}\n        rectSize={rectSize}\n        space={space}\n        leftPad={leftPad}\n        colNum={gridNum}\n        startDate={initStartDate}\n      />\n      <g transform={`translate(${leftPad}, ${topPad})`}>\n        {[...Array(gridNum)].map((_, idx) => {\n          return (\n            <g key={idx} data-column={idx}>\n              {[...Array(7)].map((_, cidx) => {\n                const dayProps: RectDayElement = {\n                  ...rectProps,\n                  rectSize,\n                  space,\n                  key: cidx,\n                  row: cidx,\n                  column: idx,\n                  fill: '#EBEDF0',\n                };\n                const currentDate = new Date(initStartDate.getTime() + oneDayTime * (idx * 7 + cidx));\n                dayProps.date = getDateToString(currentDate);\n                if (endDate instanceof Date && currentDate.getTime() > endDate.getTime()) {\n                  return null;\n                }\n                if (dayProps.date && data[dayProps.date] && panelColors && Object.keys(panelColors).length > 0) {\n                  dayProps.fill = existColor(data[dayProps.date].count || 0, nums, panelColors);\n                } else if (panelColors && panelColors[0]) {\n                  dayProps.fill = panelColors[0];\n                }\n                if (renderRect && typeof renderRect === 'function') {\n                  const elm = renderRect(dayProps, data[dayProps.date]);\n                  if (elm && React.isValidElement(elm)) {\n                    return elm;\n                  }\n                }\n                return <RectDay {...dayProps} />;\n              })}\n            </g>\n          );\n        })}\n      </g>\n    </svg>\n  );\n}\n"]}
import { SVGProps, HeatMapValue } from './SVG';
export declare const oneDayTime: number;
export declare function isValidDate(date: Date): boolean;

@@ -3,0 +4,0 @@ export declare function getDateToString(date: Date): string;

@@ -0,1 +1,2 @@

export var oneDayTime = 24 * 60 * 60 * 1000;
export function isValidDate(date) {

@@ -44,2 +45,2 @@ return date instanceof Date && !isNaN(date.getTime());

}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy50cyJdLCJuYW1lcyI6WyJpc1ZhbGlkRGF0ZSIsImRhdGUiLCJEYXRlIiwiaXNOYU4iLCJnZXRUaW1lIiwiZ2V0RGF0ZVRvU3RyaW5nIiwiZ2V0RnVsbFllYXIiLCJnZXRNb250aCIsImdldERhdGUiLCJmb3JtYXREYXRhIiwiZGF0YSIsInJlc3VsdCIsImZvckVhY2giLCJpdGVtIiwibnVtYmVyU29ydCIsImtleXMiLCJzb3J0IiwieCIsInkiLCJleGlzdENvbG9yIiwibnVtIiwibnVtcyIsInBhbmVsQ29sb3JzIiwiY29sb3IiLCJhIiwibGVuZ3RoIl0sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLFNBQVNBLFdBQVQsQ0FBcUJDLElBQXJCLEVBQWlDO0FBQ3RDLFNBQU9BLElBQUksWUFBWUMsSUFBaEIsSUFBd0IsQ0FBQ0MsS0FBSyxDQUFDRixJQUFJLENBQUNHLE9BQUwsRUFBRCxDQUFyQztBQUNEO0FBRUQsT0FBTyxTQUFTQyxlQUFULENBQXlCSixJQUF6QixFQUFxQztBQUMxQyxtQkFBVUEsSUFBSSxDQUFDSyxXQUFMLEVBQVYsY0FBZ0NMLElBQUksQ0FBQ00sUUFBTCxLQUFrQixDQUFsRCxjQUF1RE4sSUFBSSxDQUFDTyxPQUFMLEVBQXZEO0FBQ0Q7QUFFRCxPQUFPLFNBQVNDLFVBQVQsR0FBa0Q7QUFBQSxNQUE5QkMsSUFBOEIsdUVBQUosRUFBSTtBQUN2RCxNQUFNQyxNQUFvQyxHQUFHLEVBQTdDO0FBQ0FELEVBQUFBLElBQUksQ0FBQ0UsT0FBTCxDQUFhLFVBQUNDLElBQUQsRUFBVTtBQUNyQixRQUFJQSxJQUFJLENBQUNaLElBQUwsSUFBYUQsV0FBVyxDQUFDLElBQUlFLElBQUosQ0FBU1csSUFBSSxDQUFDWixJQUFkLENBQUQsQ0FBNUIsRUFBbUQ7QUFDakRZLE1BQUFBLElBQUksQ0FBQ1osSUFBTCxHQUFZSSxlQUFlLENBQUMsSUFBSUgsSUFBSixDQUFTVyxJQUFJLENBQUNaLElBQWQsQ0FBRCxDQUEzQjtBQUNBVSxNQUFBQSxNQUFNLENBQUNFLElBQUksQ0FBQ1osSUFBTixDQUFOLEdBQW9CWSxJQUFwQjtBQUNEO0FBQ0YsR0FMRDtBQU1BLFNBQU9GLE1BQVA7QUFDRDtBQUVEOztBQUNBLE9BQU8sU0FBU0csVUFBVCxHQUF5QztBQUFBLE1BQXJCQyxJQUFxQix1RUFBSixFQUFJO0FBQzlDLFNBQU9BLElBQUksQ0FBQ0MsSUFBTCxDQUFVLFVBQUNDLENBQUQsRUFBSUMsQ0FBSixFQUFVO0FBQ3pCLFFBQUlELENBQUMsR0FBR0MsQ0FBUixFQUFXLE9BQU8sQ0FBQyxDQUFSLENBQVgsS0FDSyxJQUFJRCxDQUFDLEdBQUdDLENBQVIsRUFBVyxPQUFPLENBQVA7QUFDaEIsV0FBTyxDQUFQO0FBQ0QsR0FKTSxDQUFQO0FBS0Q7QUFFRCxPQUFPLFNBQVNDLFVBQVQsR0FBK0Y7QUFBQSxNQUEzRUMsR0FBMkUsdUVBQTdELENBQTZEO0FBQUEsTUFBMURDLElBQTBEO0FBQUEsTUFBMUNDLFdBQTBDLHVFQUFKLEVBQUk7QUFDcEcsTUFBSUMsS0FBSyxHQUFHLEVBQVo7O0FBQ0EsT0FBSyxJQUFJQyxDQUFDLEdBQUcsQ0FBYixFQUFnQkEsQ0FBQyxHQUFHSCxJQUFJLENBQUNJLE1BQXpCLEVBQWlDRCxDQUFDLElBQUksQ0FBdEMsRUFBeUM7QUFDdkMsUUFBSUgsSUFBSSxDQUFDRyxDQUFELENBQUosR0FBVUosR0FBZCxFQUFtQjtBQUNqQkcsTUFBQUEsS0FBSyxHQUFHRCxXQUFXLENBQUNELElBQUksQ0FBQ0csQ0FBRCxDQUFMLENBQW5CO0FBQ0E7QUFDRDs7QUFDREQsSUFBQUEsS0FBSyxHQUFHRCxXQUFXLENBQUNELElBQUksQ0FBQ0csQ0FBRCxDQUFMLENBQW5CO0FBQ0Q7O0FBQ0QsU0FBT0QsS0FBUDtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU1ZHUHJvcHMsIEhlYXRNYXBWYWx1ZSB9IGZyb20gJy4vU1ZHJztcblxuZXhwb3J0IGZ1bmN0aW9uIGlzVmFsaWREYXRlKGRhdGU6IERhdGUpIHtcbiAgcmV0dXJuIGRhdGUgaW5zdGFuY2VvZiBEYXRlICYmICFpc05hTihkYXRlLmdldFRpbWUoKSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXREYXRlVG9TdHJpbmcoZGF0ZTogRGF0ZSkge1xuICByZXR1cm4gYCR7ZGF0ZS5nZXRGdWxsWWVhcigpfS8ke2RhdGUuZ2V0TW9udGgoKSArIDF9LyR7ZGF0ZS5nZXREYXRlKCl9YDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZvcm1hdERhdGEoZGF0YTogU1ZHUHJvcHNbJ3ZhbHVlJ10gPSBbXSkge1xuICBjb25zdCByZXN1bHQ6IFJlY29yZDxzdHJpbmcsIEhlYXRNYXBWYWx1ZT4gPSB7fTtcbiAgZGF0YS5mb3JFYWNoKChpdGVtKSA9PiB7XG4gICAgaWYgKGl0ZW0uZGF0ZSAmJiBpc1ZhbGlkRGF0ZShuZXcgRGF0ZShpdGVtLmRhdGUpKSkge1xuICAgICAgaXRlbS5kYXRlID0gZ2V0RGF0ZVRvU3RyaW5nKG5ldyBEYXRlKGl0ZW0uZGF0ZSkpO1xuICAgICAgcmVzdWx0W2l0ZW0uZGF0ZV0gPSBpdGVtO1xuICAgIH1cbiAgfSk7XG4gIHJldHVybiByZXN1bHQ7XG59XG5cbi8qKiDmjpLluo8g5q+U6L6D5Ye95pWwICovXG5leHBvcnQgZnVuY3Rpb24gbnVtYmVyU29ydChrZXlzOiBudW1iZXJbXSA9IFtdKSB7XG4gIHJldHVybiBrZXlzLnNvcnQoKHgsIHkpID0+IHtcbiAgICBpZiAoeCA8IHkpIHJldHVybiAtMTtcbiAgICBlbHNlIGlmICh4ID4geSkgcmV0dXJuIDE7XG4gICAgcmV0dXJuIDA7XG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZXhpc3RDb2xvcihudW06IG51bWJlciA9IDAsIG51bXM6IG51bWJlcltdLCBwYW5lbENvbG9yczogUmVjb3JkPG51bWJlciwgc3RyaW5nPiA9IHt9KSB7XG4gIGxldCBjb2xvciA9ICcnO1xuICBmb3IgKGxldCBhID0gMDsgYSA8IG51bXMubGVuZ3RoOyBhICs9IDEpIHtcbiAgICBpZiAobnVtc1thXSA+IG51bSkge1xuICAgICAgY29sb3IgPSBwYW5lbENvbG9yc1tudW1zW2FdXTtcbiAgICAgIGJyZWFrO1xuICAgIH1cbiAgICBjb2xvciA9IHBhbmVsQ29sb3JzW251bXNbYV1dO1xuICB9XG4gIHJldHVybiBjb2xvcjtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy50cyJdLCJuYW1lcyI6WyJvbmVEYXlUaW1lIiwiaXNWYWxpZERhdGUiLCJkYXRlIiwiRGF0ZSIsImlzTmFOIiwiZ2V0VGltZSIsImdldERhdGVUb1N0cmluZyIsImdldEZ1bGxZZWFyIiwiZ2V0TW9udGgiLCJnZXREYXRlIiwiZm9ybWF0RGF0YSIsImRhdGEiLCJyZXN1bHQiLCJmb3JFYWNoIiwiaXRlbSIsIm51bWJlclNvcnQiLCJrZXlzIiwic29ydCIsIngiLCJ5IiwiZXhpc3RDb2xvciIsIm51bSIsIm51bXMiLCJwYW5lbENvbG9ycyIsImNvbG9yIiwiYSIsImxlbmd0aCJdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxJQUFNQSxVQUFVLEdBQUcsS0FBSyxFQUFMLEdBQVUsRUFBVixHQUFlLElBQWxDO0FBRVAsT0FBTyxTQUFTQyxXQUFULENBQXFCQyxJQUFyQixFQUFpQztBQUN0QyxTQUFPQSxJQUFJLFlBQVlDLElBQWhCLElBQXdCLENBQUNDLEtBQUssQ0FBQ0YsSUFBSSxDQUFDRyxPQUFMLEVBQUQsQ0FBckM7QUFDRDtBQUVELE9BQU8sU0FBU0MsZUFBVCxDQUF5QkosSUFBekIsRUFBcUM7QUFDMUMsbUJBQVVBLElBQUksQ0FBQ0ssV0FBTCxFQUFWLGNBQWdDTCxJQUFJLENBQUNNLFFBQUwsS0FBa0IsQ0FBbEQsY0FBdUROLElBQUksQ0FBQ08sT0FBTCxFQUF2RDtBQUNEO0FBRUQsT0FBTyxTQUFTQyxVQUFULEdBQWtEO0FBQUEsTUFBOUJDLElBQThCLHVFQUFKLEVBQUk7QUFDdkQsTUFBTUMsTUFBb0MsR0FBRyxFQUE3QztBQUNBRCxFQUFBQSxJQUFJLENBQUNFLE9BQUwsQ0FBYSxVQUFDQyxJQUFELEVBQVU7QUFDckIsUUFBSUEsSUFBSSxDQUFDWixJQUFMLElBQWFELFdBQVcsQ0FBQyxJQUFJRSxJQUFKLENBQVNXLElBQUksQ0FBQ1osSUFBZCxDQUFELENBQTVCLEVBQW1EO0FBQ2pEWSxNQUFBQSxJQUFJLENBQUNaLElBQUwsR0FBWUksZUFBZSxDQUFDLElBQUlILElBQUosQ0FBU1csSUFBSSxDQUFDWixJQUFkLENBQUQsQ0FBM0I7QUFDQVUsTUFBQUEsTUFBTSxDQUFDRSxJQUFJLENBQUNaLElBQU4sQ0FBTixHQUFvQlksSUFBcEI7QUFDRDtBQUNGLEdBTEQ7QUFNQSxTQUFPRixNQUFQO0FBQ0Q7QUFFRDs7QUFDQSxPQUFPLFNBQVNHLFVBQVQsR0FBeUM7QUFBQSxNQUFyQkMsSUFBcUIsdUVBQUosRUFBSTtBQUM5QyxTQUFPQSxJQUFJLENBQUNDLElBQUwsQ0FBVSxVQUFDQyxDQUFELEVBQUlDLENBQUosRUFBVTtBQUN6QixRQUFJRCxDQUFDLEdBQUdDLENBQVIsRUFBVyxPQUFPLENBQUMsQ0FBUixDQUFYLEtBQ0ssSUFBSUQsQ0FBQyxHQUFHQyxDQUFSLEVBQVcsT0FBTyxDQUFQO0FBQ2hCLFdBQU8sQ0FBUDtBQUNELEdBSk0sQ0FBUDtBQUtEO0FBRUQsT0FBTyxTQUFTQyxVQUFULEdBQStGO0FBQUEsTUFBM0VDLEdBQTJFLHVFQUE3RCxDQUE2RDtBQUFBLE1BQTFEQyxJQUEwRDtBQUFBLE1BQTFDQyxXQUEwQyx1RUFBSixFQUFJO0FBQ3BHLE1BQUlDLEtBQUssR0FBRyxFQUFaOztBQUNBLE9BQUssSUFBSUMsQ0FBQyxHQUFHLENBQWIsRUFBZ0JBLENBQUMsR0FBR0gsSUFBSSxDQUFDSSxNQUF6QixFQUFpQ0QsQ0FBQyxJQUFJLENBQXRDLEVBQXlDO0FBQ3ZDLFFBQUlILElBQUksQ0FBQ0csQ0FBRCxDQUFKLEdBQVVKLEdBQWQsRUFBbUI7QUFDakJHLE1BQUFBLEtBQUssR0FBR0QsV0FBVyxDQUFDRCxJQUFJLENBQUNHLENBQUQsQ0FBTCxDQUFuQjtBQUNBO0FBQ0Q7O0FBQ0RELElBQUFBLEtBQUssR0FBR0QsV0FBVyxDQUFDRCxJQUFJLENBQUNHLENBQUQsQ0FBTCxDQUFuQjtBQUNEOztBQUNELFNBQU9ELEtBQVA7QUFDRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNWR1Byb3BzLCBIZWF0TWFwVmFsdWUgfSBmcm9tICcuL1NWRyc7XG5cbmV4cG9ydCBjb25zdCBvbmVEYXlUaW1lID0gMjQgKiA2MCAqIDYwICogMTAwMDtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzVmFsaWREYXRlKGRhdGU6IERhdGUpIHtcbiAgcmV0dXJuIGRhdGUgaW5zdGFuY2VvZiBEYXRlICYmICFpc05hTihkYXRlLmdldFRpbWUoKSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXREYXRlVG9TdHJpbmcoZGF0ZTogRGF0ZSkge1xuICByZXR1cm4gYCR7ZGF0ZS5nZXRGdWxsWWVhcigpfS8ke2RhdGUuZ2V0TW9udGgoKSArIDF9LyR7ZGF0ZS5nZXREYXRlKCl9YDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZvcm1hdERhdGEoZGF0YTogU1ZHUHJvcHNbJ3ZhbHVlJ10gPSBbXSkge1xuICBjb25zdCByZXN1bHQ6IFJlY29yZDxzdHJpbmcsIEhlYXRNYXBWYWx1ZT4gPSB7fTtcbiAgZGF0YS5mb3JFYWNoKChpdGVtKSA9PiB7XG4gICAgaWYgKGl0ZW0uZGF0ZSAmJiBpc1ZhbGlkRGF0ZShuZXcgRGF0ZShpdGVtLmRhdGUpKSkge1xuICAgICAgaXRlbS5kYXRlID0gZ2V0RGF0ZVRvU3RyaW5nKG5ldyBEYXRlKGl0ZW0uZGF0ZSkpO1xuICAgICAgcmVzdWx0W2l0ZW0uZGF0ZV0gPSBpdGVtO1xuICAgIH1cbiAgfSk7XG4gIHJldHVybiByZXN1bHQ7XG59XG5cbi8qKiDmjpLluo8g5q+U6L6D5Ye95pWwICovXG5leHBvcnQgZnVuY3Rpb24gbnVtYmVyU29ydChrZXlzOiBudW1iZXJbXSA9IFtdKSB7XG4gIHJldHVybiBrZXlzLnNvcnQoKHgsIHkpID0+IHtcbiAgICBpZiAoeCA8IHkpIHJldHVybiAtMTtcbiAgICBlbHNlIGlmICh4ID4geSkgcmV0dXJuIDE7XG4gICAgcmV0dXJuIDA7XG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZXhpc3RDb2xvcihudW06IG51bWJlciA9IDAsIG51bXM6IG51bWJlcltdLCBwYW5lbENvbG9yczogUmVjb3JkPG51bWJlciwgc3RyaW5nPiA9IHt9KSB7XG4gIGxldCBjb2xvciA9ICcnO1xuICBmb3IgKGxldCBhID0gMDsgYSA8IG51bXMubGVuZ3RoOyBhICs9IDEpIHtcbiAgICBpZiAobnVtc1thXSA+IG51bSkge1xuICAgICAgY29sb3IgPSBwYW5lbENvbG9yc1tudW1zW2FdXTtcbiAgICAgIGJyZWFrO1xuICAgIH1cbiAgICBjb2xvciA9IHBhbmVsQ29sb3JzW251bXNbYV1dO1xuICB9XG4gIHJldHVybiBjb2xvcjtcbn1cbiJdfQ==
{
"name": "@uiw/react-heat-map",
"version": "1.0.3",
"version": "1.1.0",
"description": "React component create calendar heatmap to visualize time series data, a la github contribution graph.",

@@ -68,3 +68,3 @@ "homepage": "https://uiwjs.github.io/react-heat-map/",

"@uiw/reset.css": "1.0.4",
"compile-less-cli": "1.7.0",
"compile-less-cli": "1.8.0",
"husky": "4.3.8",

@@ -76,4 +76,4 @@ "kkt": "6.9.0",

"react-dom": "17.0.2",
"rehype-attr": "^1.2.0",
"tsbb": "2.1.2"
"rehype-attr": "1.3.2",
"tsbb": "2.2.0"
},

@@ -80,0 +80,0 @@ "eslintConfig": {

HeatMap 日历热图
===
<!--rehype:style=text-align: center;-->

@@ -11,4 +12,5 @@ [![Build & Deploy](https://github.com/uiwjs/react-heat-map/workflows/Build%20&%20Deploy/badge.svg)](https://github.com/uiwjs/react-heat-map/actions)

[![npm bundle size](https://img.shields.io/bundlephobia/minzip/@uiw/react-heat-map)](https://bundlephobia.com/result?p=@uiw/react-heat-map)
<!--rehype:style=text-align: center;-->
React component create calendar heatmap to visualize time series data, a la github contribution graph.
A lightweight calendar heatmap react component built on SVG, customizable version of GitHub's contribution graph. Try it out on [website example](uiwjs.github.io/react-heat-map/).

@@ -24,2 +26,4 @@ ## Install

Basic usage example, Please pay warning to the time setting. ⚠️ Example: `2016/01/11`<!--rehype:style=color: green;--> -> ~~`2016-01-11`~~<!--rehype:style=color: red;-->, Support `Safari`
<!--rehype:bgWhite=true&codeSandbox=true&codePen=true-->

@@ -35,2 +39,3 @@ ```jsx

{ date: '2016/01/13', count: 10 },
...[...Array(17)].map((_, idx) => ({ date: `2016/02/${idx + 10}`, count: idx, content: '' })),
{ date: '2016/04/11', count: 2 },

@@ -52,2 +57,4 @@ { date: '2016/05/01', count: 5 },

Set the theme color style.
<!--rehype:bgWhite=true&codeSandbox=true&codePen=true-->

@@ -72,3 +79,3 @@ ```jsx

width={600}
style={{ color: 'red' }}
style={{ color: '#ad001d' }}
startDate={new Date('2016/01/01')}

@@ -81,9 +88,48 @@ panelColors={{ 0: '#f4decd', 2: '#e4b293', 4: '#d48462', 10: '#c2533a', 20: '#ad001d' }}

```
## Set Rect Style
Set the radius of the rect.
<!--rehype:bgWhite=true&codeSandbox=true&codePen=true-->
```jsx
import ReactDOM from 'react-dom';
import HeatMap from '@uiw/react-heat-map';
const Demo = () => {
const [range, setRange] = useState(5)
const value = [
{ date: '2016/01/11', count:2 },
...[...Array(17)].map((_, idx) => ({ date: `2016/01/${idx + 10}`, count: idx, content: '' })),
...[...Array(17)].map((_, idx) => ({ date: `2016/02/${idx + 10}`, count: idx, content: '' })),
{ date: '2016/04/12', count:2 },
{ date: '2016/05/01', count:5 },
{ date: '2016/05/02', count:5 },
{ date: '2016/05/03', count:1 },
{ date: '2016/05/04', count:11 },
{ date: '2016/05/08', count:32 },
];
return (
<div>
<input type="range" min="0" max="5" step="0.1" value={range} onChange={(e) => setRange(e.target.value)} /> {range}
<HeatMap
value={value}
width={600}
startDate={new Date('2016/01/01')}
rectProps={{
rx: range
}}
/>
</div>
)
};
ReactDOM.render(<Demo />, _mount_);
```
## Props
| 参数 | 说明 | 类型 | 默认值 |
|--------- |-------- |--------- |-------- |
| Property | Description | Type | Default |
| ---- | ---- | ---- | ---- |
| value | Data to be displayed, **required** | Array | `[]` |
| rectSize | Grid size | number | `11` |
| legendCellSize | Size of the legend cells, in pixel. Value equal to `0` hide legend. | number | `11` |
| startDate | Start date | Date | `new Date()` |

@@ -96,3 +142,3 @@ | endDate | End date | Date | - |

| panelColors | Backgroud color of active colors | `Record<number, string>` | `{ 0: '#EBEDF0', 8: '#7BC96F', 4: '#C6E48B', 12: '#239A3B', 32: '#196127' }` | 
| renderRect | Single block re-render | `(SVGRectElement & RectDayDefaultProps & { fill?: string }) => React.ReactNode` | - |
| renderRect | Single block re-render | `(data: SVGRectElement & RectDayDefaultProps & { fill?: string }, valueItem?: HeatMapValue) => React.ReactNode` | - |

@@ -124,5 +170,4 @@ ## Development

## License
Licensed under the MIT License.

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc