# chartjs-ror Simplifies using [Chart.js][] in Rails views. * All of Chart.js's features via one line of Ruby. * Renders charts on page load rather than DOMContentReady ([reason][browsersupport]). * Animates unless you have Modernizr and it doesn't detect canvas support ([reason][browsersupport]). You can manually override this. * Optional alternative (better?) abscissa scale calculations. * Utility method for filling in gaps in integer series. ## Installation Add this line to your application's Gemfile: gem 'chartjs-ror' And then execute: $ bundle In your JavaScript manifest, add: ```javascript //= require Chart //= require excanvas ``` You only need [excanvas][ExplorerCanvas] for IE7 and IE8. Add [Modernizr][] if you need it to your app's assets. ## Usage Each chart type has a corresponding helper for your views. The helper methods take the same arguments as their Javascript counterparts. The `options` are always optional. ```erb <%= line_chart data, options %> <%= bar_chart data, options %> <%= radar_chart data, options %> <%= polar_chart data, options %> <%= pie_chart data, options %> <%= doughnut_chart data, options %> ``` For example, to render a [line chart][linechart] in Javascript: ```javascript var data = { labels: ["January", "February", "March", "April", "May", "June", "July"], datasets: [ { label: "My First dataset", fillColor: "rgba(220,220,220,0.2)", strokeColor: "rgba(220,220,220,1)", pointColor: "rgba(220,220,220,1)", pointStrokeColor: "#fff", pointHighlightFill: "#fff", pointHighlightStroke: "rgba(220,220,220,1)", data: [65, 59, 80, 81, 56, 55, 40] }, { label: "My Second dataset", fillColor: "rgba(151,187,205,0.2)", strokeColor: "rgba(151,187,205,1)", pointColor: "rgba(151,187,205,1)", pointStrokeColor: "#fff", pointHighlightFill: "#fff", pointHighlightStroke: "rgba(151,187,205,1)", data: [28, 48, 40, 19, 86, 27, 90] } ] }; var options = {}; new Chart(ctx).Line(data,options); ``` The Ruby equivalent is: ```ruby data = { labels: ["January", "February", "March", "April", "May", "June", "July"], datasets: [ { label: "My First dataset", fillColor: "rgba(220,220,220,0.2)", strokeColor: "rgba(220,220,220,1)", pointColor: "rgba(220,220,220,1)", pointStrokeColor: "#fff", pointHighlightFill: "#fff", pointHighlightStroke: "rgba(220,220,220,1)", data: [65, 59, 80, 81, 56, 55, 40] }, { label: "My Second dataset", fillColor: "rgba(151,187,205,0.2)", strokeColor: "rgba(151,187,205,1)", pointColor: "rgba(151,187,205,1)", pointStrokeColor: "#fff", pointHighlightFill: "#fff", pointHighlightStroke: "rgba(151,187,205,1)", data: [28, 48, 40, 19, 86, 27, 90] } ] } options = {} <%= line_chart data, options %> ``` ### Options You can put anything in the `options` hash that Chart.js recognises. It also supports these non-Chart.js settings: * `:class` - class of the enclosing `
` - default is `chart`. * `:element_id` - id of the `` - default is `chart-n` where `n` is the 0-based index of the chart on the page. * `:width` - width of the canvas in px - default is `400`. * `:height` - height of the canvas in px - default is `400`. * `:generateLegend` - whether or not to generate a legend - default is `false`. ### Sample output: ```html
``` The Javascript is actually written out on a single line but you get the idea. ### Templates (tooltips and legends) and Rails views If you specify a custom template, e.g. in `legendTemplate` or `tooltipTemplate`, you must escape opening tags in the Javascript-template string, i.e. use `<%%= value %>` instead of `<%= value %>`. You need to add an escape `%` character for each level of rendering. For example: - If your view calls the chart helper directly, use `<%%= value %>`. - If your view renders a partial which calls the chart helper, use `<%%%= value %>`. ### Legend If you pass the option `generateLegend: true`, a legend will be rendered using `chart.generateLegend()` ([docs][advanced]). ### Scale calculations The plugin implements its own abscissa scale calculations which I prefer to Chart.js's (see [Chart.js#132][calculations]). You can opt-in to these calculations by passing `scaleOverride: true` in the `options` hash, without any of the other scale override keys (`scaleSteps`, `scaleStepWidth`, `scaleStartValue`). ## Intellectual Property Copyright Andrew Stewart, AirBlade Software. Released under the MIT licence. [Chart.js]: http://www.chartjs.org/ [Chartkick]: https://ankane.github.io/chartkick/ [browsersupport]: http://www.chartjs.org/docs/#notes-browser-support [linechart]: http://www.chartjs.org/docs/#lineChart-exampleUsage [piechart]: http://www.chartjs.org/docs/#pieChart-exampleUsage [Modernizr]: http://modernizr.com [ExplorerCanvas]: https://code.google.com/p/explorercanvas [advanced]: http://www.chartjs.org/docs/#advanced-usage-prototype-methods [calculations]: https://github.com/nnnick/Chart.js/issues/132