@uiw/react-heat-map
Advanced tools
Comparing version 1.3.0 to 1.3.1
import React from 'react'; | ||
import { RectDayDefaultProps } from './RectDay'; | ||
import { LegendProps } from './Legend'; | ||
@@ -9,3 +8,3 @@ export declare type HeatMapValue = { | ||
}; | ||
export declare type RectDayElement<T = SVGRectElement> = RectDayDefaultProps & React.SVGProps<T>; | ||
export declare type RectProps<T = SVGRectElement> = React.SVGProps<T>; | ||
export interface SVGProps extends React.SVGProps<SVGSVGElement> { | ||
@@ -17,7 +16,11 @@ startDate?: Date; | ||
space?: number; | ||
rectProps?: RectDayElement | RectDayDefaultProps; | ||
rectProps?: RectProps; | ||
legendRender?: LegendProps['legendRender']; | ||
rectRender?: <E = SVGRectElement>(data: E & RectDayDefaultProps & { | ||
fill?: string; | ||
}, valueItem?: HeatMapValue) => React.ReactElement | void; | ||
rectRender?: <E = SVGRectElement>(data: E & { | ||
key: number; | ||
}, valueItem: HeatMapValue & { | ||
column: number; | ||
row: number; | ||
index: number; | ||
}) => React.ReactElement | void; | ||
value?: Array<HeatMapValue>; | ||
@@ -24,0 +27,0 @@ weekLables?: string[] | false; |
@@ -28,3 +28,3 @@ "use strict"; | ||
var _RectDay = require("./RectDay"); | ||
var _Rect = require("./Rect"); | ||
@@ -140,11 +140,16 @@ var _utils = require("./utils"); | ||
var dayProps = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, rectProps), {}, { | ||
rectSize: rectSize, | ||
space: space, | ||
key: cidx, | ||
fill: '#EBEDF0', | ||
width: rectSize, | ||
height: rectSize, | ||
x: idx * (rectSize + space), | ||
y: (rectSize + space) * cidx | ||
}); | ||
var currentDate = new Date(initStartDate.getTime() + _utils.oneDayTime * (idx * 7 + cidx)); | ||
var date = (0, _utils.getDateToString)(currentDate); | ||
var dataProps = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, data[date]), {}, { | ||
row: cidx, | ||
column: idx, | ||
fill: '#EBEDF0' | ||
index: idx * 7 + cidx | ||
}); | ||
var currentDate = new Date(initStartDate.getTime() + _utils.oneDayTime * (idx * 7 + cidx)); | ||
dayProps.date = (0, _utils.getDateToString)(currentDate); | ||
@@ -155,4 +160,4 @@ if (endDate instanceof Date && currentDate.getTime() > endDate.getTime()) { | ||
if (dayProps.date && data[dayProps.date] && panelColors && Object.keys(panelColors).length > 0) { | ||
dayProps.fill = (0, _utils.existColor)(data[dayProps.date].count || 0, nums, panelColors); | ||
if (date && data[date] && panelColors && Object.keys(panelColors).length > 0) { | ||
dayProps.fill = (0, _utils.existColor)(data[date].count || 0, nums, panelColors); | ||
} else if (panelColors && panelColors[0]) { | ||
@@ -163,3 +168,5 @@ dayProps.fill = panelColors[0]; | ||
if (rectRender && typeof rectRender === 'function') { | ||
var elm = rectRender(dayProps, data[dayProps.date]); | ||
var elm = rectRender((0, _objectSpread2.default)((0, _objectSpread2.default)({}, dayProps), {}, { | ||
key: cidx | ||
}), dataProps); | ||
@@ -171,3 +178,8 @@ if (elm && /*#__PURE__*/_react.default.isValidElement(elm)) { | ||
return /*#__PURE__*/_react.default.createElement(_RectDay.RectDay, dayProps); | ||
return /*#__PURE__*/_react.default.createElement(_Rect.Rect, (0, _extends2.default)({}, dayProps, { | ||
"data-date": date, | ||
"data-index": dataProps.index, | ||
"data-row": dataProps.row, | ||
"data-column": dataProps.column | ||
})); | ||
})); | ||
@@ -178,2 +190,2 @@ }))); | ||
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","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"]} | ||
//# 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","fill","height","x","y","currentDate","date","dataProps","row","column","index","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 { Rect } from './Rect';\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 RectProps<T = SVGRectElement> = 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?: RectProps;\n  legendRender?: LegendProps['legendRender'];\n  rectRender?: <E = SVGRectElement>(\n    data: E & { key: number },\n    valueItem: HeatMapValue & {\n      column: number;\n      row: number;\n      index: number;\n    },\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: RectProps = {\n                  ...rectProps,\n                  key: cidx,\n                  fill: '#EBEDF0',\n                  width: rectSize,\n                  height: rectSize,\n                  x: idx * (rectSize + space),\n                  y: (rectSize + space) * cidx,\n                };\n                const currentDate = new Date(initStartDate.getTime() + oneDayTime * (idx * 7 + cidx));\n                const date = getDateToString(currentDate);\n                const dataProps = {\n                  ...data[date],\n                  row: cidx,\n                  column: idx,\n                  index: idx * 7 + cidx,\n                };\n\n                if (endDate instanceof Date && currentDate.getTime() > endDate.getTime()) {\n                  return null;\n                }\n                if (date && data[date] && panelColors && Object.keys(panelColors).length > 0) {\n                  dayProps.fill = existColor(data[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, key: cidx }, dataProps);\n                  if (elm && React.isValidElement(elm)) {\n                    return elm;\n                  }\n                }\n                return (\n                  <Rect\n                    {...dayProps}\n                    data-date={date}\n                    data-index={dataProps.index}\n                    data-row={dataProps.row}\n                    data-column={dataProps.column}\n                  />\n                );\n              })}\n            </g>\n          );\n        })}\n      </g>\n    </svg>\n  );\n}\n"]} |
import React from 'react'; | ||
import { RectDayDefaultProps } from './RectDay'; | ||
import { LegendProps } from './Legend'; | ||
@@ -9,3 +8,3 @@ export declare type HeatMapValue = { | ||
}; | ||
export declare type RectDayElement<T = SVGRectElement> = RectDayDefaultProps & React.SVGProps<T>; | ||
export declare type RectProps<T = SVGRectElement> = React.SVGProps<T>; | ||
export interface SVGProps extends React.SVGProps<SVGSVGElement> { | ||
@@ -17,7 +16,11 @@ startDate?: Date; | ||
space?: number; | ||
rectProps?: RectDayElement | RectDayDefaultProps; | ||
rectProps?: RectProps; | ||
legendRender?: LegendProps['legendRender']; | ||
rectRender?: <E = SVGRectElement>(data: E & RectDayDefaultProps & { | ||
fill?: string; | ||
}, valueItem?: HeatMapValue) => React.ReactElement | void; | ||
rectRender?: <E = SVGRectElement>(data: E & { | ||
key: number; | ||
}, valueItem: HeatMapValue & { | ||
column: number; | ||
row: number; | ||
index: number; | ||
}) => React.ReactElement | void; | ||
value?: Array<HeatMapValue>; | ||
@@ -24,0 +27,0 @@ weekLables?: string[] | false; |
@@ -9,3 +9,3 @@ import _extends from "@babel/runtime/helpers/extends"; | ||
import { LablesMonth } from './LablesMonth'; | ||
import { RectDay } from './RectDay'; | ||
import { Rect } from './Rect'; | ||
import { formatData, getDateToString, existColor, numberSort, isValidDate, oneDayTime } from './utils'; | ||
@@ -117,13 +117,19 @@ import Legend from './Legend'; | ||
var dayProps = _objectSpread(_objectSpread({}, rectProps), {}, { | ||
rectSize: rectSize, | ||
space: space, | ||
key: cidx, | ||
fill: '#EBEDF0', | ||
width: rectSize, | ||
height: rectSize, | ||
x: idx * (rectSize + space), | ||
y: (rectSize + space) * cidx | ||
}); | ||
var currentDate = new Date(initStartDate.getTime() + oneDayTime * (idx * 7 + cidx)); | ||
var date = getDateToString(currentDate); | ||
var dataProps = _objectSpread(_objectSpread({}, data[date]), {}, { | ||
row: cidx, | ||
column: idx, | ||
fill: '#EBEDF0' | ||
index: idx * 7 + cidx | ||
}); | ||
var currentDate = new Date(initStartDate.getTime() + oneDayTime * (idx * 7 + cidx)); | ||
dayProps.date = getDateToString(currentDate); | ||
if (endDate instanceof Date && currentDate.getTime() > endDate.getTime()) { | ||
@@ -133,4 +139,4 @@ return null; | ||
if (dayProps.date && data[dayProps.date] && panelColors && Object.keys(panelColors).length > 0) { | ||
dayProps.fill = existColor(data[dayProps.date].count || 0, nums, panelColors); | ||
if (date && data[date] && panelColors && Object.keys(panelColors).length > 0) { | ||
dayProps.fill = existColor(data[date].count || 0, nums, panelColors); | ||
} else if (panelColors && panelColors[0]) { | ||
@@ -141,3 +147,5 @@ dayProps.fill = panelColors[0]; | ||
if (rectRender && typeof rectRender === 'function') { | ||
var elm = rectRender(dayProps, data[dayProps.date]); | ||
var elm = rectRender(_objectSpread(_objectSpread({}, dayProps), {}, { | ||
key: cidx | ||
}), dataProps); | ||
@@ -149,6 +157,11 @@ if (elm && /*#__PURE__*/React.isValidElement(elm)) { | ||
return /*#__PURE__*/React.createElement(RectDay, dayProps); | ||
return /*#__PURE__*/React.createElement(Rect, _extends({}, dayProps, { | ||
"data-date": date, | ||
"data-index": dataProps.index, | ||
"data-row": dataProps.row, | ||
"data-column": dataProps.column | ||
})); | ||
})); | ||
}))); | ||
} | ||
//# 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":"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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  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"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/SVG.tsx"],"names":["React","useEffect","useMemo","useState","LablesWeek","LablesMonth","Rect","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","fill","height","x","y","currentDate","date","dataProps","row","column","index","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 { Rect } from './Rect';\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 RectProps<T = SVGRectElement> = 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?: RectProps;\n  legendRender?: LegendProps['legendRender'];\n  rectRender?: <E = SVGRectElement>(\n    data: E & { key: number },\n    valueItem: HeatMapValue & {\n      column: number;\n      row: number;\n      index: number;\n    },\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: RectProps = {\n                  ...rectProps,\n                  key: cidx,\n                  fill: '#EBEDF0',\n                  width: rectSize,\n                  height: rectSize,\n                  x: idx * (rectSize + space),\n                  y: (rectSize + space) * cidx,\n                };\n                const currentDate = new Date(initStartDate.getTime() + oneDayTime * (idx * 7 + cidx));\n                const date = getDateToString(currentDate);\n                const dataProps = {\n                  ...data[date],\n                  row: cidx,\n                  column: idx,\n                  index: idx * 7 + cidx,\n                };\n\n                if (endDate instanceof Date && currentDate.getTime() > endDate.getTime()) {\n                  return null;\n                }\n                if (date && data[date] && panelColors && Object.keys(panelColors).length > 0) {\n                  dayProps.fill = existColor(data[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, key: cidx }, dataProps);\n                  if (elm && React.isValidElement(elm)) {\n                    return elm;\n                  }\n                }\n                return (\n                  <Rect\n                    {...dayProps}\n                    data-date={date}\n                    data-index={dataProps.index}\n                    data-row={dataProps.row}\n                    data-column={dataProps.column}\n                  />\n                );\n              })}\n            </g>\n          );\n        })}\n      </g>\n    </svg>\n  );\n}\n"]} |
{ | ||
"name": "@uiw/react-heat-map", | ||
"version": "1.3.0", | ||
"version": "1.3.1", | ||
"description": "React component create calendar heatmap to visualize time series data, a la github contribution graph.", | ||
@@ -67,2 +67,3 @@ "homepage": "https://uiwjs.github.io/react-heat-map/", | ||
"@uiw/react-markdown-preview": "3.0.6", | ||
"@uiw/react-tooltip": "4.7.15", | ||
"@uiw/reset.css": "1.0.4", | ||
@@ -69,0 +70,0 @@ "compile-less-cli": "1.8.0", |
@@ -85,2 +85,3 @@ HeatMap 日历热图 | ||
``` | ||
## Set Rect Style | ||
@@ -97,4 +98,4 @@ | ||
{ 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: '' })), | ||
...[...Array(17)].map((_, idx) => ({ date: `2016/01/${idx + 10}`, count: idx })), | ||
...[...Array(17)].map((_, idx) => ({ date: `2016/02/${idx + 10}`, count: idx })), | ||
{ date: '2016/04/12', count:2 }, | ||
@@ -128,2 +129,44 @@ { date: '2016/05/01', count:5 }, | ||
## Tooltip | ||
A simple text popup tip. | ||
<!--rehype:bgWhite=true&codeSandbox=true&codePen=true--> | ||
```jsx | ||
import ReactDOM from 'react-dom'; | ||
import Tooltip from '@uiw/react-tooltip'; | ||
import HeatMap from '@uiw/react-heat-map'; | ||
const value = [ | ||
{ date: '2016/01/11', count:2 }, | ||
...[...Array(17)].map((_, idx) => ({ date: `2016/01/${idx + 10}`, count: idx, })), | ||
...[...Array(17)].map((_, idx) => ({ date: `2016/02/${idx + 10}`, count: idx, })), | ||
{ 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 }, | ||
]; | ||
const Demo = () => { | ||
return ( | ||
<HeatMap | ||
value={value} | ||
width={600} | ||
startDate={new Date('2016/01/01')} | ||
rectRender={(props, data) => { | ||
// if (!data.count) return <rect {...props} />; | ||
return ( | ||
<Tooltip key={props.key} placement="top" content={`count: ${data.count || 0}`}> | ||
<rect {...props} /> | ||
</Tooltip> | ||
); | ||
}} | ||
/> | ||
) | ||
}; | ||
ReactDOM.render(<Demo />, _mount_); | ||
``` | ||
## Props | ||
@@ -143,3 +186,3 @@ | ||
| panelColors | Backgroud color of active colors | `Record<number, string>` | `{ 0: '#EBEDF0', 8: '#7BC96F', 4: '#C6E48B', 12: '#239A3B', 32: '#196127' }` | | ||
| rectRender | Single `day` block re-render | `(data: SVGRectElement & RectDayDefaultProps & { fill?: string }, valueItem?: HeatMapValue) => React.ReactNode` | - | | ||
| rectRender | Single `day` block re-render | `<E = SVGRectElement>(data: E & { key: number }, valueItem: HeatMapValue & { column: number, row: number, index: number }) => React.ReactElement` | - | | ||
| legendRender | Single `legend` block re-render | `(props: React.SVGProps<SVGRectElement>) => React.ReactNode` | - | | ||
@@ -146,0 +189,0 @@ |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
214
112437
19
36
898