Peity (sounds like deity) is a simple jQuery
    plugin that converts an element's content into a simple <svg>
    mini pie 2/5
    donut 5,2,3
    line 5,3,9,6,5,9,7,3,5,2
    or bar chart  and is
    compatible with any browser that supports <svg>:
    Chrome, Firefox, IE9+, Opera, Safari.
  Simply call peity("pie") on a jQuery selection. There are
    two subtly different pie chart semantics, a "/" delimiter is assumed to
    mean "three out of five" and only the first two values will be drawn,
    otherwise all of the values are included in the chart and the total is the
    sum of all values.
You can also pass delimiter, fill,
    height, radius and width
    options. Passing a radius will set the correct width and height, the pie
    will always be a circle that fits the available space.
1/5 226/360 0.52/1.561 1,4 226,134 0.52,1.041 1,2,3,2,2
<span class="pie">1/5</span>
<span class="pie">226/360</span>
<span class="pie">0.52/1.561</span>
<span class="pie">1,4</span>
<span class="pie">226,134</span>
<span class="pie">0.52,1.041</span>
<span class="pie">1,2,3,2,2</span>
    $("span.pie").peity("pie")
  Donut charts are the same as pie charts and take the same options with
    an added innerRadius option which defaults to half the radius.
  
1/5 226/360 0.52/1.561 1,4 226,134 0.52,1.041 1,2,3,2,2
<span class="donut">1/5</span>
<span class="donut">226/360</span>
<span class="donut">0.52/1.561</span>
<span class="donut">1,4</span>
<span class="donut">226,134</span>
<span class="donut">0.52,1.041</span>
<span class="donut">1,2,3,2,2</span>
    $('.donut').peity('donut')
  Line charts work on a comma-separated list of digits. Line charts can
    take the following options: delimiter, fill,
    height, max, min,
    stroke, strokeWidth and width.
5,3,9,6,5,9,7,3,5,2 5,3,2,-1,-3,-2,2,3,5,2 0,-3,-6,-4,-5,-4,-7,-3,-5,-2
<span class="line">5,3,9,6,5,9,7,3,5,2</span>
<span class="line">5,3,2,-1,-3,-2,2,3,5,2</span>
<span class="line">0,-3,-6,-4,-5,-4,-7,-3,-5,-2</span>
    $(".line").peity("line")
  Bar charts work in the same way as line charts and take the following
    options: delimiter, fill, height,
    max, min, padding and
    width.
<span class="bar">5,3,9,6,5,9,7,3,5,2</span>
<span class="bar">5,3,2,-1,-3,-2,2,3,5,2</span>
<span class="bar">0,-3,-6,-4,-5,-4,-7,-3,-5,-2</span>
    $(".bar").peity("bar")
  Data attributes can be used to pass custom settings per-chart - options
    explicitly passed to the peity() function take precedence over
    data-* attributes.
1/7 2/7 3/7 4/7 5/7 6/7 7/7
<p class="data-attributes">
  <span data-peity='{ "fill": ["red", "#eeeeee"],    "innerRadius": 10, "radius": 40 }'>1/7</span>
  <span data-peity='{ "fill": ["orange", "#eeeeee"], "innerRadius": 14, "radius": 36 }'>2/7</span>
  <span data-peity='{ "fill": ["yellow", "#eeeeee"], "innerRadius": 16, "radius": 32 }'>3/7</span>
  <span data-peity='{ "fill": ["green", "#eeeeee"],  "innerRadius": 18, "radius": 28 }'>4/7</span>
  <span data-peity='{ "fill": ["blue", "#eeeeee"],   "innerRadius": 20, "radius": 24 }'>5/7</span>
  <span data-peity='{ "fill": ["indigo", "#eeeeee"], "innerRadius": 18, "radius": 20 }'>6/7</span>
  <span data-peity='{ "fill": ["violet", "#eeeeee"], "innerRadius": 15, "radius": 16 }'>7/7</span>
</p>
    $(".data-attributes span").peity("donut")
  Pie, donut and bar chart colours can be defined dynamically based on the
    values of the chart. When passing an array its values are cycled, when
    passing a function it is called once for each value allowing you to define
    each bar or segment's colour. The callback is invoked with the value, its
    index, and the full array of values - the same arguments as the callback for
    Array#forEach.
4,7,6,5 5,3,9,6,5
<span class="bar-colours-1">5,3,9,6,5,9,7,3,5,2</span>
<span class="bar-colours-2">5,3,2,-1,-3,-2,2,3,5,2</span>
<span class="bar-colours-3">0,-3,-6,-4,-5,-4,-7,-3,-5,-2</span>
<span class="pie-colours-1">4,7,6,5</span>
<span class="pie-colours-2">5,3,9,6,5</span>
    $(".bar-colours-1").peity("bar", {
  fill: ["red", "green", "blue"]
})
$(".bar-colours-2").peity("bar", {
  fill: function(value) {
    return value > 0 ? "green" : "red"
  }
})
$(".bar-colours-3").peity("bar", {
  fill: function(_, i, all) {
    var g = parseInt((i / all.length) * 255)
    return "rgb(255, " + g + ", 0)"
  }
})
$(".pie-colours-1").peity("pie", {
  fill: ["cyan", "magenta", "yellow", "black"]
})
$(".pie-colours-2").peity("pie", {
  fill: function(_, i, all) {
    var g = parseInt((i / all.length) * 255)
    return "rgb(255, " + g + ", 0)"
  }
})
  Charts can be updated by changing the the jQuery selection's text content
    and calling change() on it. The chart will be redrawn with
    the same options that were originally passed to it.
5,3,9,6,5,9,7,3,5,2,5,3,9,6,5,9,7,3,5,2
<span class="updating-chart">5,3,9,6,5,9,7,3,5,2,5,3,9,6,5,9,7,3,5,2</span>
    var updatingChart = $(".updating-chart").peity("line", { width: 64 })
setInterval(function() {
  var random = Math.round(Math.random() * 10)
  var values = updatingChart.text().split(",")
  values.shift()
  values.push(random)
  updatingChart
    .text(values.join(","))
    .change()
}, 1000)
  You can add a custom chart type by registering it with Peity with a name, defaults object, and custom chart drawing function which is called with an options object. See the existing charts for examples.
$.fn.peity.register('custom', {
    option: defaults
  }, function(opts) {
    // Implementation.
  }
)
  Peity adds a "change" event trigger to your graph elements, so if you
    update their data your can regenerate one or more charts by triggering
    change() on them.
Nothing's happened yet.
<ul>
  <li>
    <span class="graph"></span>
    <select>
      <option value="0">0</option>
      <option value="1">1</option>
      <option value="2">2</option>
      <option value="3">3</option>
      <option value="4" selected>4</option>
      <option value="5">5</option>
    </select>
  </li>
  <li>
    <span class="graph"></span>
    <select>
      <option value="0">0</option>
      <option value="1" selected>1</option>
      <option value="2">2</option>
      <option value="3">3</option>
      <option value="4">4</option>
      <option value="5">5</option>
    </select>
  </li>
  <li>
    <span class="graph"></span>
    <select>
      <option value="0">0</option>
      <option value="1">1</option>
      <option value="2">2</option>
      <option value="3" selected>3</option>
      <option value="4">4</option>
      <option value="5">5</option>
    </select>
  </li>
</ul>
<p id="notice">Nothing's happened yet.</p>
    $('select').change(function() {
  var text = $(this).val() + '/' + 5
  $(this)
    .siblings('span.graph')
    .text(text)
    .change()
  $('#notice').text('Chart updated: ' + text)
}).change()
$('span.graph').peity('pie')
  Defaults can be overridden globally like so:
$.fn.peity.defaults.pie = {
  delimiter: null,
  fill: ["#ff9900", "#fff4dd", "#ffd592"],
  height: null,
  radius: 8,
  width: null
}
$.fn.peity.defaults.donut = {
  delimiter: null,
  fill: ["#ff9900", "#fff4dd", "#ffd592"],
  height: null,
  innerRadius: null,
  radius: 8,
  width: null
}
$.fn.peity.defaults.line = {
  delimiter: ",",
  fill: "#c6d9fd",
  height: 16,
  max: null,
  min: 0,
  stroke: "#4d89f9",
  strokeWidth: 1,
  width: 32
}
$.fn.peity.defaults.bar = {
  delimiter: ",",
  fill: ["#4d89f9"],
  height: 16,
  max: null,
  min: 0,
  padding: 0.1,
  width: 32
}
  after hook that can be used to decorate a chart.data-peity attribute as JSON.max/min option when it's a string.undefined being passed to #attr().diameter pie chart option to radius.gap bar chart option to padding. It is now specified as a portion of the width of each bar and is present on both sides.<canvas> to <svg>.<svg> element's dimensions in Firefox.colour/colours options to fill.spacing bar chart option to gap.strokeColour line chart option to stroke.width: "100%") now work.devicePixelRatio - thanks @kcivey.peity() on the same element now update the existing chart rather than creating a new one.<canvas> element is only created once and $.wrapInner is no longer used to contain everything in a separate <span>.this value of the element in question.<canvas> isn't supported.First official version. Thanks to @ismasan and @olivernn for adding support for the "change" event and making it work in Firefox respectively.
It works!