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

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

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

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

Q&A

解決済

1回答

1679閲覧

Railsでお気に入りしているboardのコメントをfeedしたい。

satail

総合スコア31

Ruby on Rails

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

0グッド

0クリップ

投稿2017/04/24 10:56

編集2017/04/25 10:53

###前提・実現したいこと
railsでpublic_activityを使って、お気に入りしているboardの
ユーザーのコメントが増えるごとにfeedしたいのですが、以下のエラーでつまづいてしまいます。
feed機能を使えるようにするにはどうしたらいいでしょうか

エラーコード

NameError in FavoritesController#index undefined local variable or method `favorite_ids' for #<FavoritesController:0x007faa0c36e8f0> Did you mean? favorites_url favorite_url favorites_path favorite_path @favorites @activities = PublicActivity::Activity.order(created_at: :desc).where(owner_id: favorite_ids, owner_type: "User")

###該当のソースコード
comment.rb

class Comment < ApplicationRecord include PublicActivity::Common end

comments_controller.rb

def create @comment = @message.comments.create(comment_params) @comment.user_id = current_user.id if @comment.save comment.create_activity :create, owner: current_user redirect_to message_path(@message) else render 'new' end end

favorites_controller.rb

def index @activities = PublicActivity::Activity.order(created_at: :desc).where(owner_id: favorite_ids, owner_type: "User") end

favorites/index.html.erb

<% @activities.each do |activity| %> <%= link_to activity.owner.name, activity.owner if activity.owner -%> <%= link_to activity.trackable.name, activity.trackable -%> <% end %>

favorite.rb

class Favorite < ApplicationRecord belongs_to :user belongs_to :message validates :user_id, :uniqueness => {:scope => :message_id} end

###試したこと
こちらcastsなどを見ながら修正してみたのですがダメでした。

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

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

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

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

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

moke

2017/04/25 01:05

favorite_idsを定義していないからです。favorite model を晒すか、favorite_ids=Favorite.my_favorite.pluck(:user_id)みたいな感じで実装してください。
satail

2017/04/25 10:54

favoriteモデル追記いたしました。
guest

回答1

0

ベストアンサー

これでどうでしょう?

ruby

1def index 2 3favorite_messages_comments=Comment.joins(message: :favorite).where(:favorite=>{:user_id=>current_user.id}) 4 @activities = PublicActivity::Activity.order(created_at: :desc).joins(:comment).merge(favorite_messages_comments) 5 end

エラーが出る場合,

ruby

1def index 2favorite_messages_comment_ids=Comment.joins(message: :favorite).where(:favorites=>{:user_id=>current_user.id}).pluck(:id) 3 @activities = PublicActivity::Activity.order(created_at: :desc).where(activity_id: favorite_messages_comment_ids, activity_type: "Comment") 4 end

を追加してみてください
解説としては、お気に入りにしている記事のコメントを取得して
PublicActivity::Activityとmergeしています。
まあ中学で習った集合の共通部分のようなものです。

投稿2017/04/25 14:18

編集2017/04/28 00:08
moke

総合スコア2241

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

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

satail

2017/04/25 17:38

ありがとうございます!とてもわかりやすかったです!
satail

2017/04/27 17:14

上記のコードは理解できたのですが、 modelに合わせてfavoriteの部分をfavoritesにして試してみた結果、 Can't join 'PublicActivity::Activity' to association named 'comment'; perhaps you misspelled it? <% @activities.each do |activity| %> と出てしまいました。 joins(:comment)あたりが怪しいと思っているのですが、いい解決方法はありますでしょうか
moke

2017/04/28 00:09 編集

joins(:comment) 効きませんか、では多少遅くなりますが 修正した回答のようにしてみてください。
satail

2017/04/28 17:53

上記のコード試してみてno such column favorite_idと出ていたので favorite_idのカラムを追加してエラー箇所は回避したのですが、 favorite_idではなく、message_idで取得することは可能でしょうか? favoritesテーブル、commentsテーブルはmessage_idでお気に入りのmessage、コメントした場所をintegerで保存しているみたいなので
moke

2017/04/28 20:59

んーと、message: :favorite をmessage: :favorites にすればいいのでは? favorite_message_comment_ids はコメントのI'dを取ってきてます
satail

2017/05/02 17:47

ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問