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

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

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

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

Ruby on Rails

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

Q&A

解決済

1回答

5467閲覧

Railsのダイレクトメッセージ機能にて、一覧ページを作成したい

hiro_87g

総合スコア28

Ruby on Rails 5

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

Ruby on Rails

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

0グッド

1クリップ

投稿2018/11/23 15:56

https://qiita.com/nojinoji/items/2b3f8309a31cc6d88d03

こちらの記事をみて、DMは作成することができました。
トーク相手の名前が記載されている「DM一覧ページ」を作れたらと思い試みたところで躓いてしまいました。

下記のようにすると、ルームに関係なく全てのエントリーIDやユーザーのnicknameが表示されてしまいます。
どのように修正したら良いかアドバイスいただきたいです。
宜しくお願いします。

controllers/rooms_controller.rb

def index @rooms = Room.all @entries = Entry.all @users = User.all end

views/rooms/index.html.rb

<h1>DM一覧</h1> <% @rooms.each do |r| %> <p> <a href="/rooms/<%= r.id %>"> <% @entries.each do |e| %> <%= e.user_id %> <% end %> <% @users.each do |u| %> <%= u.nickname %> <% end %> </a> </p> <% end %>

上記の場合の表示(意図通りではない)
entyID1 entryID2 nickname1 nickname2

entyID1 entryID2 nickname1 nickname2

希望する表示
DM相手1

DM相手2

※リンクを押すとDM詳細へ移動、です。

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

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

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

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

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

guest

回答1

0

ベストアンサー

ログインしたユーザーのDMが出るようにするのであれば以下のようにすれば解決できます。

controllers/rooms_controller.rb

def index @currentEntries = current_user.entries myRoomIds = [] @currentEntries.each do |entry| myRoomIds << entry.room.id end @anotherEntries = Entry.where(room_id: myRoomIds).where('user_id != ?',@user.id) end

views/rooms/index.html.rb

<% @anotherEntries.each do |e| %> <%= link_to room_path(e.room.id) do %> <%= e.user.nickname %>とのDM<br> <% end %> <% end %>

やっていることとしては、myRoomIdsという配列を用意して、そこにeach文を用いて自分が入っているRoomのidの情報を渡してあげます。
次にEntryテーブルの自分が入っているRoom(where文で配列を渡しています)かつuser_idが自分のidではない情報を@anotherEntriesに入れます。

ビューではDM相手の名前を表示させて、そのリンクからDMページに飛べるようにしているので参考に開発を進めてみてください。

投稿2018/11/23 17:16

nojinoji

総合スコア19

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

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

hiro_87g

2018/11/24 00:57

スピーディーかつ丁寧に回答下さりありがとうございました。 おかげで希望どおりの実装ができ、また学びにもなりました。 今後も少しづつですが開発を頑張っていきたいと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問