ユーザーが [お気に入りに追加] ボタンをクリックできるイベント検索結果ページがあります。
ボタンをクリックすると、POST が実行され、イベントがユーザーのお気に入りに追加されます。もう一度検索すると、そのイベントの [お気に入りに追加] ボタンではなく [お気に入りから削除] ボタンが表示されます。
現在、お気に入りコントローラーの作成アクションでは、respond_to を使用しているため、format.js を使用すると、ユーザーはその検索結果ページにとどまることができます。
しかし、「お気に入りに追加」ボタンのパーシャルではなく、「お気に入りから削除」ボタンのパーシャルをレンダリングするにはどうすればよいですか。
そうすれば、必要に応じて、お気に入りの項目の [お気に入りから削除] をクリックできます。
以下のスクリーンショットとコード。前もって感謝します。
-------------- 検索結果アイテム レンダラー ---------------
<div id="add_remove_favorite" class="user_event_info_container">
<% if (signed_in? && current_user && current_user.id != user_event.user_id) %>
<%= render partial: "shared/add_remove_favorite",
locals: { user_event: user_event } %>
<% end %>
</div>
------------- 共有/_add_remove_favorite.html.erb ---------
<% if current_user.following?(user_event) %>
<%= render partial: 'shared/remove_favorite',
locals: { user_event: user_event } %>
<% else %>
<%= render partial: 'shared/add_favorite',
locals: { user_event: user_event } %>
<% end %>
-------------- shared/_add_favorite.html.erb ----------
<%= form_for(current_user.favorites.build(followed_event_id: user_event.id), remote: true) do |f| %>
<div class="hidden"><%= f.hidden_field :followed_event_id %></div>
<%= f.submit "Add to favorites",
class: "info_button_small user_event_summary_item" %>
<% end %>
-------------- 共有/_remove_favorite.html.erb ------------
<%= form_for(current_user.favorites.find_by_followed_event_id(user_event),
html: { method: :delete }, remote: true) do |f| %>
<%= f.submit "Remove from favorites", class: "info_inline_control info_button_small user_event_summary_item" %>
<% end %>
-------------- views/create.js.erb ------------ ここには何を入れるべきですか? 私はここで魔法を実行すると思います。
-------------- views/destroy.js.erb ------------ ここには何を入れるべきですか? 私はここで魔法を実行すると思います。