jquery sparklines charts in Angular2

While working on my internship project that uses Angular2, I had to display some data in a nice chart that provides some interactivity. After browsing around for a while, I settled for the jQuery Sparklines pie chart. It uses <canvas> to draw charts(Should I use canvas or svg?), is simple and provides useful tooltip information when you hover over it. For more info, check out the Sparklines documentation

Pie chart in action

Basic pie chart sparklines example 1

On hover sparklines example hover 2

The Sparklines pie chart looks like this. The segment of the chart is highlighted and a tooltip is displayed when hovered over.

Getting started

  1. Load jQuery library
  2. Load jquery.sparkline.js, which can be downloaded from the website
  3. An inline tag in the HTML to display the sparklines chart(e.g. <span>)
  4. Call the sparkline function to display the chart

Default line chart

The documentation provides a few ways to display the sparkline chart.

Ways to display sparklines sparklines jquery code example

Pie chart example

my piechart hover

my piechart hover 2

This is the code for my pie chart. I used the jQuery's selector to select my <span> tag, and call the sparkline function, passing in two arguments, an array of values and an object of options.

Code in Angular 2 my piechart example 1

1. Values Put the values to be displayed in an array, which is passed in as the first argument to the sparkline function.

2. Labels Similarly, put the labels for the data in an array, which is to be used later in the tooltip.

3. Tooltip We use the tooltipFormat option to format out the tooltip, and tooltipValueLookups option to provide the label to be displayed in the tooltip. Everything in the span tag is used to display a small circle with the colour of the element, specified in sliceColors. offset is used to display the label name in the tooltip {{value}} displays the value of the element ({{percent.1}}) displays the percentage with one decimal surrounded by parentheses. Besides writing simple code, the ease of customisation of the tooltip is an added bonus that provides a good developer experience.

Did you find this article valuable?

Support A techie's ramblings by becoming a sponsor. Any amount is appreciated!