使用Chartkick和Rails的多系列折线图

时间:2017-05-14 03:16:28

标签: ruby-on-rails chartkick

我试图设置一个多系列折线图,按行式显示每月总考试。

与此图表类似的东西:

enter image description here

我希望模式有颜色: (CT,MR,US,XR,MG,BD,NM)

月度日期(to_date)将是X轴数据标签。

考试模型:

has_many :modalities

模态模型:

belongs_to :exam

我的Charts控制器上有一个monthly_modalities动作:

  def monthly_modalities
    chart_data = Modality.joins(:exam).map {|m|
      {name: m.name, data: m.exam.to_date}
    }
    render json: chart_data.each do |e|
      {name: :name, data: e.group_by_month(:to_date, format: '%b', range: 1.year).sum(:total).chart_json}
    end
  end

这是创建的图表:

enter image description here

问题是重复模式不能组合在一起,并且每月日期(to_date)不会显示在X轴数据标签上。

2 个答案:

答案 0 :(得分:2)

关于这个问题,我最终asking another question,但更具体地说明了我如何循环并输出数据。

以下是解决这个问题的方法:

now = Time.now

chart_data = Modality.joins(:exam)
                     .where(exams: {from_date: (now - 1.year)..now}).map {|m|
  {name: m.name, data: {m.exam.from_date => m.total}}}

@exams = chart_data.group_by {|h| h[:name]}
             .map {|k, v| {name: k, data: v.map {|h| h[:data]}.reduce(&:merge)}}

这是显示图表所需的哈希值:

[
  {:name=>"MR", :data=>{Wed, 01 Feb 2017=>41, Wed, 01 Mar 2017=>66, Sat, 01 Apr 2017=>73, Sun, 01 Jan 2017=>44}}, 
  {:name=>"CT", :data=>{Wed, 01 Feb 2017=>4, Wed, 01 Mar 2017=>6, Sat, 01 Apr 2017=>8, Sun, 01 Jan 2017=>52}}, 
  {:name=>"XR", :data=>{Wed, 01 Mar 2017=>1}}, 
  {:name=>"US", :data=>{Sat, 01 Apr 2017=>1, Sun, 01 Jan 2017=>1}}
]

在我看来,我像这样渲染了图表:

<%= line_chart @exams %>

正确的图表:

enter image description here

答案 1 :(得分:-1)

我不知道你是否还在寻找答案,但我今天才知道如何去做。我有类似的问题,但你必须稍微使用代码才能让它适合你。这是LINK。我希望它会对你有所帮助,但对我来说它运作良好。
我将使用您的数据进行拍摄,尝试告诉我它是否有效,将其粘贴到相应的视图中:

<%= column_chart Modality.joins(:exam).group('exams.name').group_by_month(:to_date, format: '%b', range: 1.year).sum(:total) %>