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.2.0 to 1.3.0

2

lib/cjs/SVG.d.ts

@@ -18,3 +18,3 @@ import React from 'react';

legendRender?: LegendProps['legendRender'];
renderRect?: <E = SVGRectElement>(data: E & RectDayDefaultProps & {
rectRender?: <E = SVGRectElement>(data: E & RectDayDefaultProps & {
fill?: string;

@@ -21,0 +21,0 @@ }, valueItem?: HeatMapValue) => React.ReactElement | void;

@@ -46,3 +46,3 @@ "use strict";

rectProps = _ref.rectProps,
renderRect = _ref.renderRect,
rectRender = _ref.rectRender,
legendRender = _ref.legendRender,

@@ -63,3 +63,3 @@ _ref$value = _ref.value,

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

@@ -161,4 +161,4 @@ var _useState = (0, _react.useState)(0),

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

@@ -176,2 +176,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":["SVG","props","rectSize","legendCellSize","space","startDate","Date","endDate","rectProps","renderRect","legendRender","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, { LegendProps } 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  legendRender?: LegendProps['legendRender'];\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    legendRender,\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          legendRender={legendRender}\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"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/SVG.tsx"],"names":["SVG","props","rectSize","legendCellSize","space","startDate","Date","endDate","rectProps","rectRender","legendRender","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":";;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AA4Be,SAASA,GAAT,CAAaC,KAAb,EAA8B;AAC3C,aAcIA,KAAK,IAAI,EAdb;AAAA,2BACEC,QADF;AAAA,MACEA,QADF,8BACa,EADb;AAAA,iCAEEC,cAFF;AAAA,MAEEA,cAFF,oCAEmB,EAFnB;AAAA,wBAGEC,KAHF;AAAA,MAGEA,KAHF,2BAGU,CAHV;AAAA,4BAIEC,SAJF;AAAA,MAIEA,SAJF,+BAIc,IAAIC,IAAJ,EAJd;AAAA,MAKEC,OALF,QAKEA,OALF;AAAA,MAMEC,SANF,QAMEA,SANF;AAAA,MAOEC,UAPF,QAOEA,UAPF;AAAA,MAQEC,YARF,QAQEA,YARF;AAAA,wBASEC,KATF;AAAA,MASEA,KATF,2BASU,EATV;AAAA,6BAUEC,UAVF;AAAA,MAUEA,UAVF,gCAUe,CAAC,KAAD,EAAQ,KAAR,EAAe,KAAf,EAAsB,KAAtB,EAA6B,KAA7B,EAAoC,KAApC,EAA2C,KAA3C,CAVf;AAAA,8BAWEC,WAXF;AAAA,MAWEA,WAXF,iCAWgB,CAAC,KAAD,EAAQ,KAAR,EAAe,KAAf,EAAsB,KAAtB,EAA6B,KAA7B,EAAoC,KAApC,EAA2C,KAA3C,EAAkD,KAAlD,EAAyD,KAAzD,EAAgE,KAAhE,EAAuE,KAAvE,EAA8E,KAA9E,CAXhB;AAAA,8BAYEC,WAZF;AAAA,MAYEA,WAZF,iCAYgB;AAAE,OAAG,SAAL;AAAgB,OAAG,SAAnB;AAA8B,OAAG,SAAjC;AAA4C,QAAI,SAAhD;AAA2D,QAAI;AAA/D,GAZhB;AAAA,MAaKC,KAbL;;AAeA,kBAA8B,qBAAS,CAAT,CAA9B;AAAA;AAAA,MAAOC,OAAP;AAAA,MAAgBC,UAAhB;;AACA,mBAA8B,qBAAS,CAAC,CAACL,UAAF,GAAe,EAAf,GAAoB,CAA7B,CAA9B;AAAA;AAAA,MAAOM,OAAP;AAAA,MAAgBC,UAAhB;;AACA,mBAA4B,qBAAS,CAAC,CAACN,WAAF,GAAgB,EAAhB,GAAqB,CAA9B,CAA5B;AAAA;AAAA,MAAOO,MAAP;AAAA,MAAeC,SAAf;;AACA,MAAMC,MAAM,gBAAGC,eAAMC,SAAN,EAAf;;AACA,MAAMC,IAAI,GAAG,oBAAQ;AAAA,WAAM,uBAAWC,MAAM,CAACC,IAAP,CAAYb,WAAZ,EAAyBc,GAAzB,CAA6B,UAACC,IAAD;AAAA,aAAUC,QAAQ,CAACD,IAAD,EAAO,EAAP,CAAlB;AAAA,KAA7B,CAAX,CAAN;AAAA,GAAR,EAAsF,CAACf,WAAD,CAAtF,CAAb;AACA,MAAMiB,IAAI,GAAG,oBAAQ;AAAA,WAAM,uBAAWpB,KAAX,CAAN;AAAA,GAAR,EAAiC,CAACA,KAAD,CAAjC,CAAb;AACA,wBAAU;AAAA,WAAMQ,UAAU,CAAC,CAAC,CAACP,UAAF,GAAe,EAAf,GAAoB,CAArB,CAAhB;AAAA,GAAV,EAAmD,CAACA,UAAD,CAAnD;AACA,wBAAU,YAAM;AACd,QAAIU,MAAM,CAACU,OAAX,EAAoB;AAClB,UAAMC,KAAK,GAAGX,MAAM,CAACU,OAAP,CAAeE,WAAf,GAA6BhB,OAA7B,IAAwC,CAAtD;AACAD,MAAAA,UAAU,CAACkB,IAAI,CAACC,KAAL,CAAWH,KAAK,IAAI/B,QAAQ,GAAGE,KAAf,CAAhB,KAA0C,CAA3C,CAAV;AACD;AACF,GALD,EAKG,CAACF,QAAD,EAAWoB,MAAX,EAAmBlB,KAAnB,EAA0Bc,OAA1B,CALH;AAOA,wBAAU,YAAM;AACdG,IAAAA,SAAS,CAAC,CAAC,CAACR,WAAF,GAAgB,EAAhB,GAAqB,CAAtB,CAAT;AACD,GAFD,EAEG,CAACA,WAAD,CAFH;AAIA,MAAMwB,aAAa,GAAG,oBAAQ,YAAM;AAClC,QAAI,wBAAYhC,SAAZ,CAAJ,EAA4B;AAC1B,aAAO,CAACA,SAAS,CAACiC,MAAV,EAAD,GAAsBjC,SAAtB,GAAkC,IAAIC,IAAJ,CAASD,SAAS,CAACkC,OAAV,KAAsBlC,SAAS,CAACiC,MAAV,KAAqBE,iBAApD,CAAzC;AACD,KAFD,MAEO;AACL,UAAMC,OAAO,GAAG,IAAInC,IAAJ,EAAhB;AACA,aAAO,IAAIA,IAAJ,CAASmC,OAAO,CAACF,OAAR,KAAoBE,OAAO,CAACH,MAAR,KAAmBE,iBAAhD,CAAP;AACD;AACF,GAPqB,EAOnB,CAACnC,SAAD,CAPmB,CAAtB;AASA,sBACE;AAAK,IAAA,GAAG,EAAEiB;AAAV,KAAsBP,KAAtB,GACGZ,cAAc,KAAK,CAAnB,iBACC,6BAAC,eAAD;AACE,IAAA,YAAY,EAAEO,YADhB;AAEE,IAAA,WAAW,EAAEI,WAFf;AAGE,IAAA,QAAQ,EAAEZ,QAHZ;AAIE,IAAA,cAAc,EAAEC,cAJlB;AAKE,IAAA,OAAO,EAAEe,OALX;AAME,IAAA,MAAM,EAAEE,MANV;AAOE,IAAA,KAAK,EAAEhB;AAPT,IAFJ,eAYE,6BAAC,sBAAD;AAAY,IAAA,UAAU,EAAEQ,UAAxB;AAAoC,IAAA,QAAQ,EAAEV,QAA9C;AAAwD,IAAA,KAAK,EAAEE,KAA/D;AAAsE,IAAA,MAAM,EAAEgB;AAA9E,IAZF,eAaE,6BAAC,wBAAD;AACE,IAAA,WAAW,EAAEP,WADf;AAEE,IAAA,QAAQ,EAAEX,QAFZ;AAGE,IAAA,KAAK,EAAEE,KAHT;AAIE,IAAA,OAAO,EAAEc,OAJX;AAKE,IAAA,MAAM,EAAEF,OALV;AAME,IAAA,SAAS,EAAEqB;AANb,IAbF,eAqBE;AAAG,IAAA,SAAS,sBAAenB,OAAf,eAA2BE,MAA3B;AAAZ,KACG,iCAAIsB,KAAK,CAAC1B,OAAD,CAAT,EAAoBY,GAApB,CAAwB,UAACe,CAAD,EAAIC,GAAJ,EAAY;AACnC,wBACE;AAAG,MAAA,GAAG,EAAEA,GAAR;AAAa,qBAAaA;AAA1B,OACG,iCAAIF,KAAK,CAAC,CAAD,CAAT,EAAcd,GAAd,CAAkB,UAACe,CAAD,EAAIE,IAAJ,EAAa;AAC9B,UAAMC,QAAwB,+DACzBtC,SADyB;AAE5BN,QAAAA,QAAQ,EAARA,QAF4B;AAG5BE,QAAAA,KAAK,EAALA,KAH4B;AAI5B2C,QAAAA,GAAG,EAAEF,IAJuB;AAK5BG,QAAAA,GAAG,EAAEH,IALuB;AAM5BI,QAAAA,MAAM,EAAEL,GANoB;AAO5BM,QAAAA,IAAI,EAAE;AAPsB,QAA9B;AASA,UAAMC,WAAW,GAAG,IAAI7C,IAAJ,CAAS+B,aAAa,CAACE,OAAd,KAA0BC,qBAAcI,GAAG,GAAG,CAAN,GAAUC,IAAxB,CAAnC,CAApB;AACAC,MAAAA,QAAQ,CAACM,IAAT,GAAgB,4BAAgBD,WAAhB,CAAhB;;AACA,UAAI5C,OAAO,YAAYD,IAAnB,IAA2B6C,WAAW,CAACZ,OAAZ,KAAwBhC,OAAO,CAACgC,OAAR,EAAvD,EAA0E;AACxE,eAAO,IAAP;AACD;;AACD,UAAIO,QAAQ,CAACM,IAAT,IAAiBrB,IAAI,CAACe,QAAQ,CAACM,IAAV,CAArB,IAAwCtC,WAAxC,IAAuDY,MAAM,CAACC,IAAP,CAAYb,WAAZ,EAAyBuC,MAAzB,GAAkC,CAA7F,EAAgG;AAC9FP,QAAAA,QAAQ,CAACI,IAAT,GAAgB,uBAAWnB,IAAI,CAACe,QAAQ,CAACM,IAAV,CAAJ,CAAoBE,KAApB,IAA6B,CAAxC,EAA2C7B,IAA3C,EAAiDX,WAAjD,CAAhB;AACD,OAFD,MAEO,IAAIA,WAAW,IAAIA,WAAW,CAAC,CAAD,CAA9B,EAAmC;AACxCgC,QAAAA,QAAQ,CAACI,IAAT,GAAgBpC,WAAW,CAAC,CAAD,CAA3B;AACD;;AACD,UAAIL,UAAU,IAAI,OAAOA,UAAP,KAAsB,UAAxC,EAAoD;AAClD,YAAM8C,GAAG,GAAG9C,UAAU,CAACqC,QAAD,EAAWf,IAAI,CAACe,QAAQ,CAACM,IAAV,CAAf,CAAtB;;AACA,YAAIG,GAAG,iBAAIhC,eAAMiC,cAAN,CAAqBD,GAArB,CAAX,EAAsC;AACpC,iBAAOA,GAAP;AACD;AACF;;AACD,0BAAO,6BAAC,gBAAD,EAAaT,QAAb,CAAP;AACD,KA3BA,CADH,CADF;AAgCD,GAjCA,CADH,CArBF,CADF;AA4DD","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, { LegendProps } 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  legendRender?: LegendProps['legendRender'];\n  rectRender?: <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    rectRender,\n    legendRender,\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          legendRender={legendRender}\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 (rectRender && typeof rectRender === 'function') {\n                  const elm = rectRender(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"]}

@@ -18,3 +18,3 @@ import React from 'react';

legendRender?: LegendProps['legendRender'];
renderRect?: <E = SVGRectElement>(data: E & RectDayDefaultProps & {
rectRender?: <E = SVGRectElement>(data: E & RectDayDefaultProps & {
fill?: string;

@@ -21,0 +21,0 @@ }, valueItem?: HeatMapValue) => React.ReactElement | void;

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

rectProps = _ref.rectProps,
renderRect = _ref.renderRect,
rectRender = _ref.rectRender,
legendRender = _ref.legendRender,

@@ -41,3 +41,3 @@ _ref$value = _ref.value,

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

@@ -139,4 +139,4 @@ var _useState = useState(0),

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

@@ -152,2 +152,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","LablesWeek","LablesMonth","RectDay","formatData","getDateToString","existColor","numberSort","isValidDate","oneDayTime","Legend","SVG","props","rectSize","legendCellSize","space","startDate","Date","endDate","rectProps","renderRect","legendRender","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, { LegendProps } 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  legendRender?: LegendProps['legendRender'];\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    legendRender,\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          legendRender={legendRender}\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"]}
//# 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","rectRender","legendRender","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":";;;;;AAAA,OAAOA,KAAP,IAAgBC,SAAhB,EAA2BC,OAA3B,EAAoCC,QAApC,QAAoD,OAApD;AACA,SAASC,UAAT,QAA2B,cAA3B;AACA,SAASC,WAAT,QAA4B,eAA5B;AACA,SAASC,OAAT,QAA6C,WAA7C;AACA,SAASC,UAAT,EAAqBC,eAArB,EAAsCC,UAAtC,EAAkDC,UAAlD,EAA8DC,WAA9D,EAA2EC,UAA3E,QAA6F,SAA7F;AACA,OAAOC,MAAP,MAAoC,UAApC;AA4BA,eAAe,SAASC,GAAT,CAAaC,KAAb,EAA8B;AAC3C,aAcIA,KAAK,IAAI,EAdb;AAAA,2BACEC,QADF;AAAA,MACEA,QADF,8BACa,EADb;AAAA,iCAEEC,cAFF;AAAA,MAEEA,cAFF,oCAEmB,EAFnB;AAAA,wBAGEC,KAHF;AAAA,MAGEA,KAHF,2BAGU,CAHV;AAAA,4BAIEC,SAJF;AAAA,MAIEA,SAJF,+BAIc,IAAIC,IAAJ,EAJd;AAAA,MAKEC,OALF,QAKEA,OALF;AAAA,MAMEC,SANF,QAMEA,SANF;AAAA,MAOEC,UAPF,QAOEA,UAPF;AAAA,MAQEC,YARF,QAQEA,YARF;AAAA,wBASEC,KATF;AAAA,MASEA,KATF,2BASU,EATV;AAAA,6BAUEC,UAVF;AAAA,MAUEA,UAVF,gCAUe,CAAC,KAAD,EAAQ,KAAR,EAAe,KAAf,EAAsB,KAAtB,EAA6B,KAA7B,EAAoC,KAApC,EAA2C,KAA3C,CAVf;AAAA,8BAWEC,WAXF;AAAA,MAWEA,WAXF,iCAWgB,CAAC,KAAD,EAAQ,KAAR,EAAe,KAAf,EAAsB,KAAtB,EAA6B,KAA7B,EAAoC,KAApC,EAA2C,KAA3C,EAAkD,KAAlD,EAAyD,KAAzD,EAAgE,KAAhE,EAAuE,KAAvE,EAA8E,KAA9E,CAXhB;AAAA,8BAYEC,WAZF;AAAA,MAYEA,WAZF,iCAYgB;AAAE,OAAG,SAAL;AAAgB,OAAG,SAAnB;AAA8B,OAAG,SAAjC;AAA4C,QAAI,SAAhD;AAA2D,QAAI;AAA/D,GAZhB;AAAA,MAaKC,KAbL;;AAeA,kBAA8B1B,QAAQ,CAAC,CAAD,CAAtC;AAAA;AAAA,MAAO2B,OAAP;AAAA,MAAgBC,UAAhB;;AACA,mBAA8B5B,QAAQ,CAAC,CAAC,CAACuB,UAAF,GAAe,EAAf,GAAoB,CAArB,CAAtC;AAAA;AAAA,MAAOM,OAAP;AAAA,MAAgBC,UAAhB;;AACA,mBAA4B9B,QAAQ,CAAC,CAAC,CAACwB,WAAF,GAAgB,EAAhB,GAAqB,CAAtB,CAApC;AAAA;AAAA,MAAOO,MAAP;AAAA,MAAeC,SAAf;;AACA,MAAMC,MAAM,gBAAGpC,KAAK,CAACqC,SAAN,EAAf;AACA,MAAMC,IAAI,GAAGpC,OAAO,CAAC;AAAA,WAAMQ,UAAU,CAAC6B,MAAM,CAACC,IAAP,CAAYZ,WAAZ,EAAyBa,GAAzB,CAA6B,UAACC,IAAD;AAAA,aAAUC,QAAQ,CAACD,IAAD,EAAO,EAAP,CAAlB;AAAA,KAA7B,CAAD,CAAhB;AAAA,GAAD,EAA+E,CAACd,WAAD,CAA/E,CAApB;AACA,MAAMgB,IAAI,GAAG1C,OAAO,CAAC;AAAA,WAAMK,UAAU,CAACkB,KAAD,CAAhB;AAAA,GAAD,EAA0B,CAACA,KAAD,CAA1B,CAApB;AACAxB,EAAAA,SAAS,CAAC;AAAA,WAAMgC,UAAU,CAAC,CAAC,CAACP,UAAF,GAAe,EAAf,GAAoB,CAArB,CAAhB;AAAA,GAAD,EAA0C,CAACA,UAAD,CAA1C,CAAT;AACAzB,EAAAA,SAAS,CAAC,YAAM;AACd,QAAImC,MAAM,CAACS,OAAX,EAAoB;AAClB,UAAMC,KAAK,GAAGV,MAAM,CAACS,OAAP,CAAeE,WAAf,GAA6Bf,OAA7B,IAAwC,CAAtD;AACAD,MAAAA,UAAU,CAACiB,IAAI,CAACC,KAAL,CAAWH,KAAK,IAAI9B,QAAQ,GAAGE,KAAf,CAAhB,KAA0C,CAA3C,CAAV;AACD;AACF,GALQ,EAKN,CAACF,QAAD,EAAWoB,MAAX,EAAmBlB,KAAnB,EAA0Bc,OAA1B,CALM,CAAT;AAOA/B,EAAAA,SAAS,CAAC,YAAM;AACdkC,IAAAA,SAAS,CAAC,CAAC,CAACR,WAAF,GAAgB,EAAhB,GAAqB,CAAtB,CAAT;AACD,GAFQ,EAEN,CAACA,WAAD,CAFM,CAAT;AAIA,MAAMuB,aAAa,GAAGhD,OAAO,CAAC,YAAM;AAClC,QAAIS,WAAW,CAACQ,SAAD,CAAf,EAA4B;AAC1B,aAAO,CAACA,SAAS,CAACgC,MAAV,EAAD,GAAsBhC,SAAtB,GAAkC,IAAIC,IAAJ,CAASD,SAAS,CAACiC,OAAV,KAAsBjC,SAAS,CAACgC,MAAV,KAAqBvC,UAApD,CAAzC;AACD,KAFD,MAEO;AACL,UAAMyC,OAAO,GAAG,IAAIjC,IAAJ,EAAhB;AACA,aAAO,IAAIA,IAAJ,CAASiC,OAAO,CAACD,OAAR,KAAoBC,OAAO,CAACF,MAAR,KAAmBvC,UAAhD,CAAP;AACD;AACF,GAP4B,EAO1B,CAACO,SAAD,CAP0B,CAA7B;AASA,sBACE;AAAK,IAAA,GAAG,EAAEiB;AAAV,KAAsBP,KAAtB,GACGZ,cAAc,KAAK,CAAnB,iBACC,oBAAC,MAAD;AACE,IAAA,YAAY,EAAEO,YADhB;AAEE,IAAA,WAAW,EAAEI,WAFf;AAGE,IAAA,QAAQ,EAAEZ,QAHZ;AAIE,IAAA,cAAc,EAAEC,cAJlB;AAKE,IAAA,OAAO,EAAEe,OALX;AAME,IAAA,MAAM,EAAEE,MANV;AAOE,IAAA,KAAK,EAAEhB;AAPT,IAFJ,eAYE,oBAAC,UAAD;AAAY,IAAA,UAAU,EAAEQ,UAAxB;AAAoC,IAAA,QAAQ,EAAEV,QAA9C;AAAwD,IAAA,KAAK,EAAEE,KAA/D;AAAsE,IAAA,MAAM,EAAEgB;AAA9E,IAZF,eAaE,oBAAC,WAAD;AACE,IAAA,WAAW,EAAEP,WADf;AAEE,IAAA,QAAQ,EAAEX,QAFZ;AAGE,IAAA,KAAK,EAAEE,KAHT;AAIE,IAAA,OAAO,EAAEc,OAJX;AAKE,IAAA,MAAM,EAAEF,OALV;AAME,IAAA,SAAS,EAAEoB;AANb,IAbF,eAqBE;AAAG,IAAA,SAAS,sBAAelB,OAAf,eAA2BE,MAA3B;AAAZ,KACG,mBAAIoB,KAAK,CAACxB,OAAD,CAAT,EAAoBW,GAApB,CAAwB,UAACc,CAAD,EAAIC,GAAJ,EAAY;AACnC,wBACE;AAAG,MAAA,GAAG,EAAEA,GAAR;AAAa,qBAAaA;AAA1B,OACG,mBAAIF,KAAK,CAAC,CAAD,CAAT,EAAcb,GAAd,CAAkB,UAACc,CAAD,EAAIE,IAAJ,EAAa;AAC9B,UAAMC,QAAwB,mCACzBpC,SADyB;AAE5BN,QAAAA,QAAQ,EAARA,QAF4B;AAG5BE,QAAAA,KAAK,EAALA,KAH4B;AAI5ByC,QAAAA,GAAG,EAAEF,IAJuB;AAK5BG,QAAAA,GAAG,EAAEH,IALuB;AAM5BI,QAAAA,MAAM,EAAEL,GANoB;AAO5BM,QAAAA,IAAI,EAAE;AAPsB,QAA9B;;AASA,UAAMC,WAAW,GAAG,IAAI3C,IAAJ,CAAS8B,aAAa,CAACE,OAAd,KAA0BxC,UAAU,IAAI4C,GAAG,GAAG,CAAN,GAAUC,IAAd,CAA7C,CAApB;AACAC,MAAAA,QAAQ,CAACM,IAAT,GAAgBxD,eAAe,CAACuD,WAAD,CAA/B;;AACA,UAAI1C,OAAO,YAAYD,IAAnB,IAA2B2C,WAAW,CAACX,OAAZ,KAAwB/B,OAAO,CAAC+B,OAAR,EAAvD,EAA0E;AACxE,eAAO,IAAP;AACD;;AACD,UAAIM,QAAQ,CAACM,IAAT,IAAiBpB,IAAI,CAACc,QAAQ,CAACM,IAAV,CAArB,IAAwCpC,WAAxC,IAAuDW,MAAM,CAACC,IAAP,CAAYZ,WAAZ,EAAyBqC,MAAzB,GAAkC,CAA7F,EAAgG;AAC9FP,QAAAA,QAAQ,CAACI,IAAT,GAAgBrD,UAAU,CAACmC,IAAI,CAACc,QAAQ,CAACM,IAAV,CAAJ,CAAoBE,KAApB,IAA6B,CAA9B,EAAiC5B,IAAjC,EAAuCV,WAAvC,CAA1B;AACD,OAFD,MAEO,IAAIA,WAAW,IAAIA,WAAW,CAAC,CAAD,CAA9B,EAAmC;AACxC8B,QAAAA,QAAQ,CAACI,IAAT,GAAgBlC,WAAW,CAAC,CAAD,CAA3B;AACD;;AACD,UAAIL,UAAU,IAAI,OAAOA,UAAP,KAAsB,UAAxC,EAAoD;AAClD,YAAM4C,GAAG,GAAG5C,UAAU,CAACmC,QAAD,EAAWd,IAAI,CAACc,QAAQ,CAACM,IAAV,CAAf,CAAtB;;AACA,YAAIG,GAAG,iBAAInE,KAAK,CAACoE,cAAN,CAAqBD,GAArB,CAAX,EAAsC;AACpC,iBAAOA,GAAP;AACD;AACF;;AACD,0BAAO,oBAAC,OAAD,EAAaT,QAAb,CAAP;AACD,KA3BA,CADH,CADF;AAgCD,GAjCA,CADH,CArBF,CADF;AA4DD","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, { LegendProps } 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  legendRender?: LegendProps['legendRender'];\n  rectRender?: <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    rectRender,\n    legendRender,\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          legendRender={legendRender}\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 (rectRender && typeof rectRender === 'function') {\n                  const elm = rectRender(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"]}
{
"name": "@uiw/react-heat-map",
"version": "1.2.0",
"version": "1.3.0",
"description": "React component create calendar heatmap to visualize time series data, a la github contribution graph.",

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

@@ -140,3 +140,3 @@ HeatMap 日历热图

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

@@ -143,0 +143,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