npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@hackclub/react-calendar-heatmap

v1.8.2

Published

A calendar heatmap component built on SVG, inspired by Github's commit calendar graph.

Downloads

171

Readme

This is a fork of the original with a few bug fixes & improvements.

React Calendar Heatmap

A calendar heatmap component built on SVG, inspired by github's commit calendar graph. The component expands to size of container and is super configurable. Try it out on CodeSandbox.

npm version Build Status bundle size

react-calendar-heatmap screenshot

Setup

Install the npm module with yarn or npm:

yarn add @hackclub/react-calendar-heatmap

Usage

Import the component:

import CalendarHeatmap from '@hackclub/react-calendar-heatmap'

Import styles. You can directly import from the module, which requires a CSS loader:

import '@hackclub/react-calendar-heatmap/dist/styles.css'

A CSS loader is included by default in create-react-app. If you don't have a CSS loader, you can simply copy the stylesheet into a file in your project and import it instead.

To show a basic heatmap from January 1st to April 1st:

<CalendarHeatmap
  startDate={new Date('2016-01-01')}
  endDate={new Date('2016-04-01')}
  values={[
    { date: '2016-01-01', count: 12 },
    { date: '2016-01-22', count: 122 },
    { date: '2016-01-30', count: 38 },
    // ...and so on
  ]}
/>

Props

| Name | Type | Description | | --------------------- | ----------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | | values | Required, Array of Object | Required array of objects which each have a date property, which can be a Date object, parseable string, or millisecond timestamp. Example: [{ date: '2016-01-01', count: 6 }] | | startDate | String, Number, or Date | Start of date range. | | endDate | String, Number, or Date | End of date range - a Date object, parseable string, or millisecond timestamp. | | showMonthLabels | Boolean | Toggle for removing month labels. | | showWeekdayLabels | Boolean | Toggle for removing weekday labels. | | showOutOfRangeDays | Boolean | Toggle display of extra days in week that are past endDate and before beginning of range. | | horizontal | Boolean | Whether to orient horizontally or vertically. Can be used in combination with endDate to show just the current month. | | gutterSize | Number | Size of gutters relative to squares. | | onClick | Function | Callback to invoke when a square is clicked, e.g. (value) => alert(value) | | onMouseOver | Function | Callback to invoke when mouse pointer is over a square, e.g. (event, value) => console.log(event, value) | | onMouseLeave | Function | Callback to invoke when mouse pointer leaves a square, e.g. (event, value) => console.log(event, value) | | titleForValue | Function | Function to determine each square's title attribute, for generating 3rd party hover tooltips (may also need to configure tooltipDataAttrs). Example: (value) =>Date is ${value.date} | |tooltipDataAttrs | Object or Function | Set data attributes for all squares, for generating 3rd party hover tooltips. Either an object like{ 'data-tooltip': 'tooltip' }or a function like(value) => { return { 'data-tooltip': 'Tooltip: ' + value } } | |classForValue | Function | Callback for determining CSS class to apply to each value, e.g.(value) => (value.count > 0 ? 'blue' : 'white'). | | monthLabels | Array of String | An array with 12 strings representing the text from January to December, e.g.['01', '02', ..., '12'] | |weekdayLabels | Array of String | An array with 7 strings representing the text from Sunday to Saturday | |transformDayElement| Function | A function to further transform generated svg element for a single day. Can be used to attach event handlers, add tooltips and more. Example:(element, value, index) => React.cloneElement(element, { title: value.date })`. |

Configuring colors

To use the color scale shown in the live demo based on the github contribution graph, you can set the classForValue prop, a function that determines which CSS class to apply to each value:

<CalendarHeatmap
  values={[
    { date: '2016-01-01', count: 1 },
    { date: '2016-01-03', count: 4 },
    { date: '2016-01-06', count: 2 },
    // ...and so on
  ]}
  classForValue={(value) => {
    if (!value) {
      return 'color-empty'
    }
    return `color-scale-${value.count}`
  }}
/>

Then you use CSS to set colors for each class:

.react-calendar-heatmap .color-scale-1 {
  fill: #9be9a8;
}
.react-calendar-heatmap .color-scale-2 {
  fill: #40c463;
}
.react-calendar-heatmap .color-scale-3 {
  fill: #30a14e;
}
.react-calendar-heatmap .color-scale-4 {
  fill: #216e39;
}

Contributing

Take a look at CONTRIBUTING.md to see how to develop on react-calendar-heatmap.

License

react-calendar-heatmap is Copyright © 2016 PatientsLikeMe, Inc. and is released under an MIT License. See COPYING for details.