繁体   English   中英

Chartkick / Rails:使用来自对象而不是模型的数据构建line_chart

[英]Chartkick/Rails: Build line_chart using data from an object instead of a Model

我正在尝试使用从API检索的数据绘制一个简单的line_chart,但文档示例仅使用来自常规ActiveRecord模型的数据,而且我正在苦苦挣扎。 由于我没有在模型上操作,因此无法使用文档中解释的任何方法(组等)

我有一个对REST API的调用,我得到了一个有两个属性的对象(还有一些属性,但这两个是我现在感兴趣的那些),ORDER_CODE和LEAD_TIME。 我只想显示一个line_chart,其中X轴为order_codes,Y轴为lead_times。

我的控制器代码是这样的,我使用Dish将散列从Json.parse转换为对象。 API调用正在运行,我正在我的应用程序中成功使用数据。

leadtimes = Dish(JSON.parse RestClient.get(ENV['API'], params: { PART: @order.PART }))

在视图中:

<%= line_chart @data%> 

我正在尝试这个,但我得到一个空图表:

@data = leadtimes.map do |value|
  [
    order_code: value.ORDER_CODE, lead_time: value.LEAD_TIME
  ]
end

我从API获得的JSON如下所示:

[{"ORDER_CODE"=>519805, "PART"=>"00049", "LEAD_TIME"=>29, "DATE"=>"2015-03-03T00:00:00"}, {"ORDER_CODE"=>517297, "PART"=>"00149", "LEAD_TIME"=>54, "DATE"=>"2014-11-26T00:00:00"}]

我终于通过在变量提前期中包含的原始哈希数组上使用collect方法来实现它,如OP中所示。

@data = leadtimes.collect{|i| [i['ORDER_CODE'], i['lead_time']]}

只需将@data作为参数传递给line_chart,图表就会被相关地绘制出来。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM