Project

chartx

0.0
No commit activity in last 3 years
No release in over 3 years
Generate beautiful charts in rails
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.3
>= 0

Runtime

< 5.0, >= 3.2.0
 Project Readme

Chartx Gem Version

Chartx is a Ruby gem helps you to develop fancy interactive data visualizations with one line of Ruby code!:) It's a ruby wrapper of nvd3, which is an attempt to build re-usable charts and chart components for d3.js without taking away the power that d3.js gives you.

Installation

To include Chartx into your rails project, add this line to your application's Gemfile:

gem 'chartx'

And then execute:

$ bundle install

To add the necessary javascript files into your asset pipeline add

//= require chartx-core
//= require chartx-model

in app/assets/javascripts/application.js

If you only need a subset of models e.g. lineChart you can add

//= require nvd3/lib/d3.v2
//= require nvd3/src/core
//= require nvd3/src/tooltip
//= require nvd3/src/utils.js
//= require nvd3/src/models/lineChart
//= require nvd3/src/models/legend.js
//= require nvd3/src/models/axis.js
//= require nvd3/src/models/scatter.js
//= require nvd3/src/models/line.js

to your application.js. All the models can be found in https://github.com/xianhengma/nvd3/tree/chartx-branch/src/models

Examples

Pie Chart:

<%= pie_chart @pie_data %>

ScreenShot

Line Chart:

<%= line_chart @line_data %>

ScreenShot

Discrete Bar Chart:

<%= discrete_bar_chart @discrete_bar_data %>

ScreenShot

Line Chart with Focus (View Finder):

<%= line_with_focus_chart @line_with_focus_data %>

ScreenShot

Scatter Chart:

<%= scatter_chart @scatter_data %>

ScreenShot

Bullet Chart:

<%= bullet_chart @bullet_data %>

ScreenShot

Stacked Area Bar Chart:

<%= stacked_area_chart @stacked_area_data %>

ScreenShot

ScreenShot

Multi Bar Chart:

<%= multi_bar_chart @multi_bar_data %>

ScreenShot

Multi Horizontal Bar Chart:

<%= multi_bar_horizontal_chart @multi_bar_horizontal_data %>

ScreenShot

Data Format

Data for Chartx (except Pie Chart) are in the following format:

@data = [
	{
		:key => "<Series name>",
		:color => "<CSS color>"
		:values => [
			{:label => 0, :value => 10},
			{:label => 1, :value => 20},
			{:label => 2, :value => 30}
			....
		]
	},
	{
		key: "<Series name>"
		...
	}
]

Data for Pie Chart is in the following format:

@data = [
	{
		:label => "<name1>",
		:value => 31
	},
	{
		:label => "<name2>",
		:value => 31

	},
	{
		...
	}
		
]

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request