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.2 to 1.0.3

21

lib/cjs/SVG.js

@@ -88,2 +88,10 @@ "use strict";

}, [rectSize, svgRef, space, leftPad]);
var initStartDate = (0, _react.useMemo)(function () {
if ((0, _utils.isValidDate)(startDate)) {
return !startDate.getDay() ? startDate : new Date(startDate.getTime() - startDate.getDay() * oneDayTime);
} else {
var newDate = new Date();
return new Date(newDate.getTime() - newDate.getDay() * oneDayTime);
}
}, [startDate]);
return /*#__PURE__*/_react.default.createElement("svg", (0, _extends2.default)({

@@ -110,10 +118,7 @@ ref: svgRef

});
var currentDate = new Date(initStartDate.getTime() + oneDayTime * (idx * 7 + cidx));
dayProps.date = (0, _utils.getDateToString)(currentDate);
if (startDate instanceof Date) {
var currentDate = new Date(startDate.getTime() + oneDayTime * (idx * 7 + cidx));
dayProps.date = (0, _utils.getDateToString)(currentDate);
if (endDate instanceof Date && currentDate.getTime() > endDate.getTime()) {
return null;
}
if (endDate instanceof Date && currentDate.getTime() > endDate.getTime()) {
return null;
}

@@ -141,2 +146,2 @@

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","Array","_","idx","cidx","dayProps","key","row","column","fill","currentDate","getTime","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 } 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  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                if (startDate instanceof Date) {\n                  const currentDate = new Date(startDate.getTime() + oneDayTime * (idx * 7 + cidx));\n                  dayProps.date = getDateToString(currentDate);\n                  if (endDate instanceof Date && currentDate.getTime() > endDate.getTime()) {\n                    return null;\n                  }\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":["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"]}
import { SVGProps, HeatMapValue } from './SVG';
export declare function isValidDate(date: Date): boolean;
export declare function getDateToString(date: Date): string;

@@ -3,0 +4,0 @@ export declare function formatData(data?: SVGProps['value']): Record<string, HeatMapValue>;

@@ -6,2 +6,3 @@ "use strict";

});
exports.isValidDate = isValidDate;
exports.getDateToString = getDateToString;

@@ -59,2 +60,2 @@ exports.formatData = formatData;

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

@@ -9,3 +9,3 @@ import _extends from "@babel/runtime/helpers/extends";

import { RectDay } from './RectDay';
import { formatData, getDateToString, existColor, numberSort } from './utils';
import { formatData, getDateToString, existColor, numberSort, isValidDate } from './utils';
var oneDayTime = 24 * 60 * 60 * 1000;

@@ -67,2 +67,10 @@ export default function SVG(props) {

}, [rectSize, svgRef, space, leftPad]);
var initStartDate = useMemo(function () {
if (isValidDate(startDate)) {
return !startDate.getDay() ? startDate : new Date(startDate.getTime() - startDate.getDay() * oneDayTime);
} else {
var newDate = new Date();
return new Date(newDate.getTime() - newDate.getDay() * oneDayTime);
}
}, [startDate]);
return /*#__PURE__*/React.createElement("svg", _extends({

@@ -90,9 +98,7 @@ ref: svgRef

if (startDate instanceof Date) {
var currentDate = new Date(startDate.getTime() + oneDayTime * (idx * 7 + cidx));
dayProps.date = getDateToString(currentDate);
var currentDate = new Date(initStartDate.getTime() + oneDayTime * (idx * 7 + cidx));
dayProps.date = getDateToString(currentDate);
if (endDate instanceof Date && currentDate.getTime() > endDate.getTime()) {
return null;
}
if (endDate instanceof Date && currentDate.getTime() > endDate.getTime()) {
return null;
}

@@ -118,2 +124,2 @@

}
//# 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","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","Array","_","idx","cidx","dayProps","key","row","column","fill","currentDate","getTime","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 } 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  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                if (startDate instanceof Date) {\n                  const currentDate = new Date(startDate.getTime() + oneDayTime * (idx * 7 + cidx));\n                  dayProps.date = getDateToString(currentDate);\n                  if (endDate instanceof Date && currentDate.getTime() > endDate.getTime()) {\n                    return null;\n                  }\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","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"]}
import { SVGProps, HeatMapValue } from './SVG';
export declare function isValidDate(date: Date): boolean;
export declare function getDateToString(date: Date): string;

@@ -3,0 +4,0 @@ export declare function formatData(data?: SVGProps['value']): Record<string, HeatMapValue>;

@@ -1,5 +0,4 @@

function isValidDate(date) {
export function isValidDate(date) {
return date instanceof Date && !isNaN(date.getTime());
}
export function getDateToString(date) {

@@ -45,2 +44,2 @@ return "".concat(date.getFullYear(), "/").concat(date.getMonth() + 1, "/").concat(date.getDate());

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

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

"@types/react-dom": "17.0.5",
"@uiw/react-code-preview": "1.11.13",
"@uiw/react-github-corners": "1.2.0",
"@uiw/react-markdown-preview": "3.0.6",
"@uiw/reset.css": "1.0.4",
"@uiw/react-markdown-preview": "3.0.6",
"@uiw/react-github-corners": "1.2.0",
"@uiw/react-code-preview": "1.11.13",
"compile-less-cli": "1.7.0",

@@ -76,2 +76,3 @@ "husky": "4.3.8",

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

@@ -78,0 +79,0 @@ },

@@ -30,7 +30,9 @@ HeatMap 日历热图

const value = [
{ date: '2016/01/11', count:2, content:['一条消息来了!','一条消息来了!'] },
{ date: '2016/04/11', count:2, content:['一条消息来了!'] },
{ date: '2016/05/01', count:5, content:['需要显示的数据'] },
{ date: '2016/05/02', count:5, content:['空的没有消息'] },
{ date: '2016/05/04', count:11, content:['些放弃的人会这样想'] },
{ date: '2016/01/11', count: 2 },
{ date: '2016/01/12', count: 20 },
{ date: '2016/01/13', count: 10 },
{ date: '2016/04/11', count: 2 },
{ date: '2016/05/01', count: 5 },
{ date: '2016/05/02', count: 5 },
{ date: '2016/05/04', count: 11 },
];

@@ -46,2 +48,32 @@ return (

## Set Color
<!--rehype:bgWhite=true&codeSandbox=true&codePen=true-->
```jsx
import ReactDOM from 'react-dom';
import HeatMap from '@uiw/react-heat-map';
const Demo = () => {
const value = [
{ date: '2016/01/11', count:2 },
{ 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 (
<HeatMap
value={value}
width={600}
style={{ color: 'red' }}
startDate={new Date('2016/01/01')}
panelColors={{ 0: '#f4decd', 2: '#e4b293', 4: '#d48462', 10: '#c2533a', 20: '#ad001d' }}
/>
)
};
ReactDOM.render(<Demo />, _mount_);
```
## Props

@@ -48,0 +80,0 @@

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