前提・実現したいこと
メッセージ送信機能を非同期化しました。メッセージ本体に削除機能をつけたくmessage.jsに${group.id}を反映させたいです。(groupにmessageをネストさせてます)
該当のソースコード
js
1$(function(){ 2 function buildHTML(message){ 3 var html = 4 `<%= link_to "/groups/${group.id }/messages/${message.id}", method: :delete do%> 5 <div class="card"> 6 <div class="card-body"> 7 <h3 class="card-content">${message.content}</h3> 8 <h6 class="card-user">${message.user_name}</h6> 9 </div> 10 </div> 11 <h1>????</h1>` 12 return html; 13 } 14 $('#new_message').on('submit', function(e){ 15 e.preventDefault(); 16 var formData = new FormData(this); 17 var url = $(this).attr('action') 18 $.ajax({ 19 url: url, 20 type: "POST", 21 data: formData, 22 dataType: 'json', 23 processData: false, 24 contentType: false 25 }) 26 .done(function(data){ 27 var html = buildHTML(data); 28 $('.row.c').append(html); 29 $('.row.c').animate({ scrollTop: $('.row.c')[0].scrollHeight}); 30 $('form')[0].reset(); 31 $('.btn.btn-success').prop( 'disabled', false ); 32 }) 33 .fail(function() { 34 alert("メッセージ送信に失敗しました"); 35 }); 36}) 37});
controller
1class MessagesController < ApplicationController 2 before_action :set_group 3 before_action :move_to_index, except: :index 4 5 def index 6 @message = Message.new 7 @messages = @group.messages.includes(:user) 8 end 9 10 def create 11 @message = @group.messages.new(message_params) 12 if @message.save 13 respond_to do |format| 14 format.json 15 end 16 else 17 redirect_to group_messages_path(@group) 18 end 19 end 20 21 def destroy 22 message = Message.find(params[:id]) 23 message.destroy 24 redirect_to group_messages_path(@group) 25 end 26 27 private 28 29 def message_params 30 params.require(:message).permit(:content).merge(user_id: current_user.id) 31 end 32 33 def set_group 34 @group = Group.find(params[:group_id]) 35 end 36 37 def move_to_index 38 redirect_to action: :index unless user_signed_in? 39 end 40end 41
jbuilder
1json.id @message.id 2json.user_name @message.user.name 3json.created_at @message.created_at.strftime("%Y年%m月%d日 %H時%M分") 4json.content @message.content 5json.image @message.image
試したこと
set_groupにrespond_toやrenderを試し、jbuilderに@group.idを記述しましたが反映されないです。
ご教授よろしくお願いします。
補足情報(FW/ツールのバージョンなど)
Rails 5.0.7.2
ruby 2.5.1p57 (2018-03-29 revision 63029) [x86_64-darwin18]
あなたの回答
tips
プレビュー