アプリのリツイート/リピン機能を作成しました。ビューで重複した「コンテンツ」を非表示にするにはどうすればよいですか? テーブルのすべてのエントリが表示されるように、インデックス ビューで設定しました<%= render @letsgos %>
。
ユーザー A が投稿したものをユーザー B が再投稿できるように、リツイート/リピンを設定します。データベースでは、ユーザー A からの元の投稿がコピーされ、列「repost_from_user_id」には「コンテンツ」の元の ID が表示されます。
コントローラ:
class LetsgosController < ApplicationController
before_action :correct_user, only: :destroy
def create
@letsgo = current_user.letsgos.build(letsgo_params)
if @letsgo.save
flash[:success] = "Date posted!"
redirect_to root_url
else
flash[:error] = "Date was not posted!"
redirect_to root_url
end
end
def destroy
@letsgo.destroy
redirect_to root_url
end
def index
@letsgos = Letsgo.all
@eat = Letsgo.where(:tag => 'Eat')
end
def eatdrink
@eatdrink = Letsgo.where(:tag => 'Eat/Drink')
end
def listenwatch
@listenwatch = Letsgo.where(:tag => 'Listen/Watch')
end
def play
@play = Letsgo.where(:tag => 'Play')
end
def explore
@explore = Letsgo.where(:tag => 'Explore')
end
def other
@other = Letsgo.where(:tag => 'Other')
end
def repost
@letsgo = Letsgo.find(params[:id]).repost(current_user)
redirect_to root_url
end
private
def letsgo_params
params.require(:letsgo).permit(:content, :tag)
end
def correct_user
@letsgo = current_user.letsgos.find_by(id: params[:id])
redirect_to root_url if @letsgo.nil?
end
end
モデル:
class Letsgo < ActiveRecord::Base
belongs_to :user
default_scope -> { order('created_at DESC') }
validates :content, presence: true, length: { maximum: 360 }
validates :user_id, presence: true
def repost(user_object)
new_letsgo = self.dup #duplicates the entire object, except for the ID
new_letsgo.user_id = user_object.id
new_letsgo.repost_from_user_id = self.id #save the user id of original repost, to keep track of where it originally came from
new_letsgo.save
end
def is_repost?
repost_from_user_id.present?
end
def original_user
User.find(repost_from_user_id) if is_repost?
end
end