質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

1050閲覧

Chartkickのグラフをテーブルのレコードごとでindexに表示させたい。

8hachi8

総合スコア2

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2020/07/30 00:03

編集2020/07/30 00:11

よろしくお願いします。

現在Railsでアプリ製作中でして、Chartkickのグラフを導入しております。
グラフの表示をレコードごとに表示させたいのですが、現状全てのグラフが同じ内容となってしまっています。

haml

1.contents.row 2 - @reports.each do |report| 3 .content_post 4 = bar_chart @data 5 .more 6 %span= image_tag 'arrow_top.png' 7 %ul.more_list 8 %li 9 = link_to '詳細', report_path(report.id), method: :get 10 - if user_signed_in? && current_user.id == report.user_id 11 %li 12 = link_to '編集', edit_report_path(report.id), method: :get 13 %li 14 = link_to '削除', report_path(report.id), method: :delete 15 %p= report.due 16 %span.name 17 %a{href: "/users/#{report.user.id}"} 18 %span 投稿者 19 = report.user.nickname

controller

1def index 2 @reports = Report.includes(:user).order("due DESC") 3 @data = Detail.group(:work).sum(:hour) 4end

each文で回しているので、恐らくコントローラーの@dataに付け足して記述するか何かだとは思うのですが、なかなか解決できません。ビュー画面とデータベースも添付いたしますのでご存知の方、ご回答のほどお願いいたします。
ビュー
reportsテーブル
detailsテーブル

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

お察しの通り毎回同じ @data で書いているからです。
each で回している report から @data 相当を取り出す必要があります。
ReportとDetailの関係がわからないので具体的には書けませんが

class Report def data # report から @data相当を抜き出す end end #viewにて   = bar_chart report.data

投稿2020/07/30 03:13

winterboum

総合スコア23329

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

8hachi8

2020/07/30 20:10 編集

ご回答ありがとうございます! #modelにて class Report < ApplicationRecord def graph details.group(:work).sum(:hour) end end #viewにて = bar_chart report.graph という記述でそれぞれ表示させることができました。 Detailと記述していたのも悪かったかも知れませんね、本当にありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問