前提・実現したいこと
ruby '2.5.3' rails'5.2.2'
Railsでポートフォリオ作成中で現在、ユーザーの最近の動向を「アクティビティ」として表現しようとしています。
メッセージとコメントを混ぜてcreated_at順に並べようとして失敗しているので何が原因か教えて頂けますでしょうか。
発生している問題・エラーメッセージ
NoMethodError in Users#show undefined method `order'
該当のソースコード
users_contoroller.rb
ruby
1def show 2 @user = User.find(params[:id]) 3 @comments = @user.comments 4 @messages = @user.messages 5 @activity = [] 6 @activity = @comments + @messages 7end
show.html.haml
.activity - @activity.order(created_at: :desc).each do |active| .active - if activ.has_attribute?(:content) = active.content - elsif activ.has_attribute?(:text) = active.text
ターミナル
NoMethodError in Users#show undefined method `order' ターミナル [2] pry(#<UsersController>)> @activity => [#<Comment:0x00007ff881696dc0 id: 2, text: "記事へのコメント", user_id: 7, article_id: 11, created_at: Wed, 29 Jan 2020 01:38:34 JST +09:00, updated_at: Wed, 29 Jan 2020 01:38:34 JST +09:00>, #<Comment:0x00007ff8816405d8 id: 3, text: "aaa", user_id: 7, article_id: 11, created_at: Wed, 29 Jan 2020 01:53:32 JST +09:00, updated_at: Wed, 29 Jan 2020 01:53:32 JST +09:00>, #<Comment:0x00007ff881637fa0 id: 4, text: "!?!?", user_id: 7, article_id: 11, created_at: Wed, 29 Jan 2020 01:56:58 JST +09:00, updated_at: Wed, 29 Jan 2020 01:56:58 JST +09:00>, #<Comment:0x00007ff881637870 id: 5, text: "いいい", user_id: 7, article_id: 11, created_at: Sat, 01 Feb 2020 01:06:43 JST +09:00, updated_at: Sat, 01 Feb 2020 01:06:43 JST +09:00>, #<Comment:0x00007ff8816370c8 id: 6, text: "コメント", user_id: 7, article_id: 11, created_at: Mon, 03 Feb 2020 19:11:25 JST +09:00, updated_at: Mon, 03 Feb 2020 19:11:25 JST +09:00>, #<Message:0x00007ff880cfc468 id: 4, content: "ああ", group_id: 3, user_id: 7, created_at: Wed, 29 Jan 2020 00:59:45 JST +09:00, updated_at: Wed, 29 Jan 2020 00:59:45 JST +09:00>, #<Message:0x00007ff88131be48 id: 5, content: "??", group_id: 3, user_id: 7, created_at: Wed, 29 Jan 2020 01:14:53 JST +09:00, updated_at: Wed, 29 Jan 2020 01:14:53 JST +09:00>, #<Message:0x00007ff88131af48 id: 6, content: "!!!", group_id: 3, user_id: 7, created_at: Wed, 29 Jan 2020 01:56:12 JST +09:00, updated_at: Wed, 29 Jan 2020 01:56:12 JST +09:00>, #<Message:0x00007ff88131a138 id: 7, content: "何故", group_id: 3, user_id: 7, created_at: Wed, 29 Jan 2020 01:57:34 JST +09:00, updated_at: Wed, 29 Jan 2020 01:57:34 JST +09:00>, #<Message:0x00007ff881319198 id: 8, content: "あああ", group_id: 3, user_id: 7, created_at: Sat, 01 Feb 2020 01:06:15 JST +09:00, updated_at: Sat, 01 Feb 2020 01:06:15 JST +09:00>, #<Message:0x00007ff88130fb98 id: 9, content: "メッセージ", group_id: 3, user_id: 7, created_at: Mon, 03 Feb 2020 19:11:04 JST +09:00, updated_at: Mon, 03 Feb 2020 19:11:04 JST +09:00>]
user.rb
has_many :articles, dependent: :destroy has_many :comments, dependent: :destroy has_many :messages, dependent: :destroy #中略 has_many :group_users, dependent: :destroy has_many :groups, through: :group_users
article.rb
belongs_to :user has_many :comments, dependent: :destroy
comment.rb
belongs_to :user belongs_to :article
group.rb
has_many :group_users, dependent: :destroy has_many :users, through: :group_users has_many :messages
message.rb
belongs_to :group belongs_to :user
試したこと
show.html.haml
- @activity.each do |active| = active.created_at
にするとcreated_at自体は表示がされますが
当然ターミナルの順番どうりComment→Messageの順番でしか取り出せません。
他モデル間で配列を混ぜる時に何かしらのルールに引っかかっているのでしょうか
また全く別の方法でこんな方法がある、ここの知識が不足している等も含めてアドバイスをお願いします。
回答1件
あなたの回答
tips
プレビュー