Google Chart 4 Rails (GC4R)

By , March 12, 2009 12:06 am

Charts are generated by Google API.

Install: ruby script/plugin install http://gc4r.googlecode.com/svn/trunk/

Supported features:
1.line chart
2.bar chart (vertical and horizontal)
3.pie chart (both 2D and 3D)
4.title, title color and size
5.data colors and legend
6.data scaling
7.multiple axis

#Controller

use_google_charts

#In method of controller

Default Chart or Hello World Chart

@chart = GoogleChart.new

Set the width of chart

@chart = GoogleLineChart.new :width => 300, :height => 200

Set the data

dataset = GoogleChartDataset.new :data => [10,50,4,10,16]
data = GoogleChartData.new :datasets => dataset
@chart = GoogleLineChart.new :width => 300, :height => 200
@chart.data = data

add a chart title

dataset = GoogleChartDataset.new :data => [10,50,4,10,16]
data = GoogleChartData.new :datasets => dataset
@chart = GoogleLineChart.new :width => 200, :height => 150, :title => 'Java vs. Ruby Montly Job Opportunities'
@chart.data = data

Set title in array instead of string


dataset = GoogleChartDataset.new :data => [10,50,4,10,16]
data = GoogleChartData.new :datasets => dataset
@chart = GoogleLineChart.new :width => 200, :height => 150, :title => ['Java vs. Ruby', 'Montly Job Opportunities']
@chart.data = data

Multiple data in chart


dataset1 = GoogleChartDataset.new :data => [10,50,4,10,16]
dataset2 = GoogleChartDataset.new :data => [99, 81, 25, 54, 80]
data = GoogleChartData.new :datasets => [dataset1, dataset2]
@chart = GoogleLineChart.new :width => 200, :height => 150, :title => ['Java vs. Ruby', 'Montly Job Opportunities']
@chart.data = data

Add colors


dataset1 = GoogleChartDataset.new :data => [10,50,4,10,16],:color => 'FF0000'
dataset2 = GoogleChartDataset.new :data =>[99,81,25,54,80],:color => '0000FF'
data = GoogleChartData.new :datasets => [dataset1, dataset2]
@chart = GoogleLineChart.new :width => 200, :height => 150, :title => ['Java vs. Ruby', 'Montly Job Opportunities']
@chart.data = data

Define legend

dataset1 = GoogleChartDataset.new :data =>[10,50,4,10,16],:color => 'FF0000', :title => 'Java'
dataset2 = GoogleChartDataset.new :data=>[99,81,25,54,80],:color => '0000FF', :title => 'Ruby'
data = GoogleChartData.new :datasets => [dataset1, dataset2]
@chart = GoogleLineChart.new :width => 200, :height => 150, :title => ['Java vs. Ruby', 'Montly Job Opportunities']
@chart.data = data

Define Axis

dataset1 = GoogleChartDataset.new :data =>[10,50,4,10,16],:color => 'FF0000', :title => 'Java'
dataset2 = GoogleChartDataset.new :data=>[99,81,25,54,80],:color => '0000FF', :title => 'Ruby'
data = GoogleChartData.new :datasets => [dataset1, dataset2]
axis = GoogleChartAxis.new :axis  => [GoogleChartAxis::LEFT, GoogleChartAxis::BOTTOM]
@chart = GoogleLineChart.new :width => 250, :height => 150, :title => ['Java vs. Ruby', 'Montly Job Opportunities']
@chart.data = data
@chart.axis = axis

Define Right and X Axis


dataset1 = GoogleChartDataset.new :data=> [10,50,4,10,16],:color => 'FF0000',  :title => 'Java'
dataset2 = GoogleChartDataset.new :data=>[99,81,25,54,80],:color => '0000FF', :title => 'Ruby'
data = GoogleChartData.new :datasets => [dataset1, dataset2]
axis = GoogleChartAxis.new :axis  => [GoogleChartAxis::LEFT, GoogleChartAxis::BOTTOM,  GoogleChartAxis::RIGHT, GoogleChartAxis::BOTTOM]
@chart = GoogleLineChart.new :width => 300, :height => 200, :title => ['Java vs. Ruby', 'Montly Job Opportunities']
@chart.data = data
@chart.axis = axis

Define Bar Chart:


@chart = GoogleBarChart.new :width => 300, :height => 200, :title => ['Java vs. Ruby', 'Montly Job Opportunities']

Define 3D Pie Chart:


@chart = GooglePieChart.new :width => 400, :height => 200, :title => ['Java vs. Ruby', 'Montly Job Opportunities'], :chart_type  => GooglePieChart::PIE_3D

#view:

<%= image_tag @chart.to_url %>

Export to Excel in Ruby on Rails

By , March 11, 2009 11:35 pm

Below code will help to export the data in excel in Ruby on Rails

#Controller

class UserController < ApplicationController
def export
headers['Content-Type'] = "application/vnd.ms-excel"
headers['Content-Disposition'] = 'attachment; filename="report.xls"'
headers['Cache-Control'] = ''
@users = User.find(:all)
end

#View

export.html.erb


<%=link_to "Export as Excel", export_person_url %>

_report.html.erb


<table border="1">
  <tr>
    <th>Name</th>
  </tr>
  <% @users.each do |u| %>
  <tr>
   <td><%= u.name %></td>
  <% end %>
 </tr>
</table>

Panorama Theme by Themocracy