Description
Create beautiful JavaScript charts with one line of Ruby. No more fighting with charting libraries!
Works with Rails, Sinatra and most browsers (including IE 6)
Chartkick alternatives and similar gems
Based on the "Data Visualization" category.
Alternatively, view Chartkick alternatives based on common mentions on social networks and blogs.
-
RailRoady
Ruby on Rails 3/4/5 model and controller UML class diagram generator. (`brew/port/apt-get install graphviz` before use!) -
LazyHighCharts
Make highcharts a la ruby , works in rails 5.X / 4.X / 3.X, and other ruby web frameworks -
TrianglePattern
Dynamically generate beautiful triangle background patterns using delaunay triangulation
Scout Monitoring - Performance metrics and, now, Logs Management Monitoring with Scout Monitoring
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of Chartkick or a related project?
README
Chartkick
Create beautiful JavaScript charts with one line of Ruby. No more fighting with charting libraries!
:fire: For admin charts and dashboards, check out Blazer, and for advanced visualizations, check out Vega
:two_hearts: A perfect companion to Groupdate, Hightop, and ActiveMedian
Quick Start
Add this line to your application’s Gemfile:
gem "chartkick"
Then follow the instructions for your framework:
This sets up Chartkick with Chart.js. For other charting libraries and frameworks, see detailed instructions.
Rails 7 / Importmap
In config/importmap.rb
, add:
pin "chartkick", to: "chartkick.js"
pin "Chart.bundle", to: "Chart.bundle.js"
And in app/javascript/application.js
, add:
import "chartkick"
import "Chart.bundle"
Rails 7 / esbuild or Webpack
Run:
yarn add chartkick chart.js
And in app/javascript/application.js
, add:
import "chartkick/chart.js"
Rails 6 / Webpacker
Run:
yarn add chartkick chart.js
And in app/javascript/packs/application.js
, add:
import "chartkick/chart.js"
Rails 5 / Sprockets
In app/assets/javascripts/application.js
, add:
//= require chartkick
//= require Chart.bundle
Charts
Line chart
<%= line_chart User.group_by_day(:created_at).count %>
Pie chart
<%= pie_chart Goal.group(:name).count %>
Column chart
<%= column_chart Task.group_by_hour_of_day(:created_at, format: "%l %P").count %>
Bar chart
<%= bar_chart Shirt.group(:size).sum(:price) %>
Area chart
<%= area_chart Visit.group_by_minute(:created_at).maximum(:load_time) %>
Scatter chart
<%= scatter_chart City.pluck(:size, :population) %>
Geo chart - Google Charts
<%= geo_chart Medal.group(:country).count %>
Timeline - Google Charts
<%= timeline [
["Washington", "1789-04-29", "1797-03-03"],
["Adams", "1797-03-03", "1801-03-03"],
["Jefferson", "1801-03-03", "1809-03-03"]
] %>
Multiple series
<%= line_chart [
{name: "Workout", data: {"2021-01-01" => 3, "2021-01-02" => 4}},
{name: "Call parents", data: {"2021-01-01" => 5, "2021-01-02" => 3}}
] %>
or
<%= line_chart Feat.group(:goal_id).group_by_week(:created_at).count %>
Data
Data can be a hash, array, or URL.
Hash
<%= line_chart({"2021-01-01" => 2, "2021-01-02" => 3}) %>
Array
<%= line_chart [["2021-01-01", 2], ["2021-01-02", 3]] %>
URL
Make your pages load super fast and stop worrying about timeouts. Give each chart its own endpoint.
<%= line_chart completed_tasks_charts_path %>
And in your controller, pass the data as JSON.
class ChartsController < ApplicationController
def completed_tasks
render json: Task.group_by_day(:completed_at).count
end
end
For multiple series, add chart_json
at the end.
render json: Task.group(:goal_id).group_by_day(:completed_at).count.chart_json
Options
Id, width, and height
<%= line_chart data, id: "users-chart", width: "800px", height: "500px" %>
Min and max values
<%= line_chart data, min: 1000, max: 5000 %>
min
defaults to 0 for charts with non-negative values. Use nil
to let the charting library decide.
Min and max for x-axis - Chart.js
<%= line_chart data, xmin: "2021-01-01", xmax: "2022-01-01" %>
Colors
<%= line_chart data, colors: ["#b00", "#666"] %>
Stacked columns or bars
<%= column_chart data, stacked: true %>
Discrete axis
<%= line_chart data, discrete: true %>
Label (for single series)
<%= line_chart data, label: "Value" %>
Axis titles
<%= line_chart data, xtitle: "Time", ytitle: "Population" %>
Straight lines between points instead of a curve
<%= line_chart data, curve: false %>
Hide points
<%= line_chart data, points: false %>
Show or hide legend
<%= line_chart data, legend: false %>
Specify legend position
<%= line_chart data, legend: "bottom" %>
Donut chart
<%= pie_chart data, donut: true %>
Prefix, useful for currency - Chart.js, Highcharts
<%= line_chart data, prefix: "$" %>
Suffix, useful for percentages - Chart.js, Highcharts
<%= line_chart data, suffix: "%" %>
Set a thousands separator - Chart.js, Highcharts
<%= line_chart data, thousands: "," %>
Set a decimal separator - Chart.js, Highcharts
<%= line_chart data, decimal: "," %>
Set significant digits - Chart.js, Highcharts
<%= line_chart data, precision: 3 %>
Set rounding - Chart.js, Highcharts
<%= line_chart data, round: 2 %>
Show insignificant zeros, useful for currency - Chart.js, Highcharts
<%= line_chart data, round: 2, zeros: true %>
Friendly byte sizes - Chart.js
<%= line_chart data, bytes: true %>
Specify the message when data is loading
<%= line_chart data, loading: "Loading..." %>
Specify the message when data is empty
<%= line_chart data, empty: "No data" %>
Refresh data from a remote source every n
seconds
<%= line_chart url, refresh: 60 %>
You can pass options directly to the charting library with:
<%= line_chart data, library: {backgroundColor: "#eee"} %>
See the documentation for Chart.js, Google Charts, and Highcharts for more info.
To customize datasets in Chart.js, use:
<%= line_chart data, dataset: {borderWidth: 10} %>
You can pass this option to individual series as well.
Global Options
To set options for all of your charts, create an initializer config/initializers/chartkick.rb
with:
Chartkick.options = {
height: "400px",
colors: ["#b00", "#666"]
}
Customize the html
Chartkick.options[:html] = '<div id="%{id}" style="height: %{height};">%{loading}</div>'
You capture the JavaScript in a content block with:
Chartkick.options[:content_for] = :charts_js
Then, in your layout, use:
<%= yield :charts_js %>
For Padrino, use yield_content
instead of yield
.
This is great for including all of your JavaScript at the bottom of the page.
Multiple Series
You can pass a few options with a series:
name
data
color
dataset
- Chart.js onlypoints
- Chart.js onlycurve
- Chart.js only
Code
If you want to use the charting library directly, get the code with:
<%= line_chart data, code: true %>
The code will be logged to the JavaScript console. JavaScript functions cannot be logged, so it may not be identical.
Download Charts
Chart.js only
Give users the ability to download charts. It all happens in the browser - no server-side code needed.
<%= line_chart data, download: true %>
Safari will open the image in a new window instead of downloading.
Set the filename
<%= line_chart data, download: {filename: "boom"} %>
Set the background color
<%= line_chart data, download: {background: "#ffffff"} %>
Set title
<%= line_chart data, title: "Awesome chart" %>
Installation
Add this line to your application's Gemfile:
gem "chartkick"
Next, choose your charting library.
Chart.js
For Rails 7 / Importmap, in config/importmap.rb
, add:
pin "chartkick", to: "chartkick.js"
pin "Chart.bundle", to: "Chart.bundle.js"
And in app/javascript/application.js
, add:
import "chartkick"
import "Chart.bundle"
For Rails 6 / Webpacker, run:
yarn add chartkick chart.js
And in app/javascript/packs/application.js
, add:
import "chartkick/chart.js"
For Rails 5 / Sprockets, in app/assets/javascripts/application.js
, add:
//= require chartkick
//= require Chart.bundle
Google Charts
In your layout or views, add:
<%= javascript_include_tag "https://www.gstatic.com/charts/loader.js" %>
For Rails 7 / Importmap, in config/importmap.rb
, add:
pin "chartkick", to: "chartkick.js"
And in app/javascript/application.js
, add:
import "chartkick"
For Rails 6 / Webpacker, run:
yarn add chartkick
And in app/javascript/packs/application.js
, add:
import "chartkick"
For Rails 5 / Sprockets, in app/assets/javascripts/application.js
, add:
//= require chartkick
To specify a language or Google Maps API key, use:
Chartkick.configure({language: "de", mapsApiKey: "..."})
before your charts.
Highcharts
For Rails 7 / Importmap, run:
bin/importmap pin highcharts --download
And in config/importmap.rb
, add:
pin "chartkick", to: "chartkick.js"
And in app/javascript/application.js
, add:
import "chartkick"
import Highcharts from "highcharts"
window.Highcharts = Highcharts
For Rails 6 / Webpacker, run:
yarn add chartkick highcharts
And in app/javascript/packs/application.js
, add:
import "chartkick/highcharts"
For Rails 5 / Sprockets, download highcharts.js into vendor/assets/javascripts
(or use yarn add highcharts
in Rails 5.1+), and in app/assets/javascripts/application.js
, add:
//= require chartkick
//= require highcharts
Sinatra and Padrino
Download chartkick.js and include it manually.
<script src="chartkick.js"></script>
Then include the charting library.
Chart.js - download Chart.js and the date-fns adapter bundle
<script src="chart.js"></script>
<script src="chartjs-adapter-date-fns.bundle.js"></script>
Google Charts
<script src="https://www.gstatic.com/charts/loader.js"></script>
Highcharts - download highcharts.js
<script src="highcharts.js"></script>
Multiple Libraries
If more than one charting library is loaded, choose between them with:
<%= line_chart data, adapter: "google" %> <!-- or highcharts or chartjs -->
JavaScript API
Access a chart with:
var chart = Chartkick.charts["chart-id"]
Get the underlying chart object with:
chart.getChartObject()
You can also use:
chart.getElement()
chart.getData()
chart.getOptions()
chart.getAdapter()
Update the data with:
chart.updateData(newData)
You can also specify new options:
chart.setOptions(newOptions)
// or
chart.updateData(newData, newOptions)
Refresh the data from a remote source:
chart.refreshData()
Redraw the chart with:
chart.redraw()
Destroy the chart with:
chart.destroy()
Loop over charts with:
Chartkick.eachChart( function(chart) {
// do something
})
Content Security Policy (CSP)
Check out how to configure CSP
No Ruby? No Problem
Check out chartkick.js
Tutorials
- Charts with Chartkick and Groupdate
- Creando gráficos en Ruby on Rails con Chartkick y Chart.js
- Make Easy Graphs and Charts on Rails with Chartkick
- Practical Graphs on Rails: Chartkick in Practice
Upgrading
4.0
If you use Sprockets, update the gem and you’re good to go!
If you use Webpacker, run:
yarn upgrade chartkick --latest
If you use Chart.js with Webpacker, also run:
yarn upgrade chart.js --latest
And in app/javascript/packs/application.js
, change:
require("chartkick")
require("chart.js")
to:
require("chartkick/chart.js")
History
View the changelog
Contributing
Everyone is encouraged to help improve this project. Here are a few ways you can help:
- Report bugs
- Fix bugs and submit pull requests
- Write, clarify, or fix documentation
- Suggest or add new features
To get started with development:
git clone https://github.com/ankane/chartkick.git
cd chartkick
bundle install
bundle exec rake test