3

Seer を使用して、過去 7 日間の新規ユーザーを日別に表示するローリング グラフを実装したいと考えています。

Seerをインストールしました:

http://www.idolhands.com/ruby-on-rails/gems-plugins-and-engines/graphing-for-ruby-on-rails-with-seer

どのように実装するか頭を悩ませています。

プロットしたいユーザーの配列があります:

@users = User.all( :条件 => {:created_at => 7.days.ago..Time.zone.now})

:data_method を実装して、created_at 日付でそれらをロールアップする正しい方法がわかりません。

Seerでこれまたは同様のことをした人はいますか?

Seer のサンプル ページ (上記のリンク) を見た後、これを説明できる私より賢い人はいますか?

4

1 に答える 1

6

過去 7 日間の日別の新規ユーザー数を表示しようとしていると想定しています。もしそうなら、あなたは次のことができます

コントローラーコード

# declare a struct to hold the results
UserCountByDate = Struct.new(:date, :count) 

def report
  @user_counts = User.count( :group => "DATE(created_at)", 
                   :conditions => ["created_at >= ? ", 7.days.ago], 
                   :order => "DATE(created_at) ASC"
                 ).collect do |date, count| 
                   UserCountByDate.new(date, count)
                 end

end

コードを表示

<div id="chart"></div>

<%= Seer::visualize(
      @user_counts, 
      :as => :column_chart,
      :in_element =>'chart', 
      :series => {
        :series_label => 'date',
        :data_method => 'count'
      },
      :chart_options => {
        :height => 300,
        :width => 100 * @user_counts.size,
        :is_3_d => true,
        :legend => 'none',
        :colors => "[{color:'#990000', darker:'#660000'}]",
        :title => "New users in last 7 days",
        :title_x => 'date',
        :title_y => 'count'
      }
    )
 -%>

data_method、チャートの入力として使用される配列の各行に存在する必要があります。このActiveRecord countメソッドはハッシュを返します。これは、およびメソッドstructに応答する配列に変換されます。datecount

于 2010-03-14T08:47:15.987 に答える