前提・実現したいこと
アルバイトのシフト作成のアプリを作っています。
DBに保存されたデータをjsを使い繰り返し処理されているdiv要素をshift_tableのtdの中にドラッグ&ドロップができるようにしました。
その上でドロップした要素はdiv要素なのでこの中にある文字列をDBに保存したい。
発生している問題・エラーメッセージ
ドロップした後にそのコードを見てみると
html
1<td id="shift_num1" ondragover="onDragOver(event);" ondrop="onDrop(event);"> 2 <div id="human1" class="employee_name" draggable="true" ondragstart="onDragStart(event);"> 3 田中 ひろし 4 </div> 5</td>
このようになっており、divの中に保存したい値が入ってしまいます。
該当のソースコード
Ruby,
1<div class="shift_main"> 2 <%= params[:date_save] %> 3 <div class="shift_set"> 4 <%= form_with(model: @form, url: root_path, local: true) do |form| %> 5 <table class="shift_table"> 6 <tbody class="shift_table_body"> 7 <tr class="shift_line"> 8 <td id="shift_num1" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 9 <td id="shift_num2" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 10 </tr> 11 <tr class="shift_line"> 12 <td id="shift_num3" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 13 <td id="shift_num4" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 14 </tr> 15 <tr class="shift_line"> 16 <td id="shift_num5" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 17 <td id="shift_num6" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 18 </tr> 19 <tr class="shift_line"> 20 <td id="shift_num7" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 21 <td id="shift_num8" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 22 </tr> 23 <tr class="shift_line"> 24 <td id="shift_num9" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 25 <td id="shift_num10" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 26 </tr> 27 <tr class="shift_line"> 28 <td id="shift_num11" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 29 <td id="shift_num12" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 30 </tr> 31 <tr class="shift_line"> 32 <td id="shift_num13" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 33 <td id="shift_num14" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 34 </tr> 35 <tr class="shift_line"> 36 <td id="shift_num15" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 37 <td id="shift_num16" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 38 </tr> 39 <tr class="shift_line"> 40 <td id="shift_num17" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 41 <td id="shift_num18" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 42 </tr> 43 <tr class="shift_line"> 44 <td id="shift_num19" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 45 <td id="shift_num20" ondragover="onDragOver(event);" ondrop="onDrop(event);"></td> 46 </tr> 47 </tbody> 48 </table> 49 <% end %> 50 <table> 51 <tbody> 52 <% @num.each do |day| %> 53 <tr> 54 <td class="employee"> 55 <div id="human1" class="employee_name" draggable="true" ondragstart="onDragStart(event);"> 56 <%= day.name %> 57 </div> 58 </td> 59 </tr> 60 <% end %> 61 </tbody> 62 </table> 63 </div> 64</div> 65<script type="text/javascript"> 66function onDragStart(event) 67{ 68 const nodes = Array.from(document.querySelectorAll(".employee_name")); 69 const index = nodes.findIndex(v=>v===event.target); 70 event.dataTransfer.setData('text/plain', index); 71} 72 73 74function onDragOver(event) { 75 event.preventDefault(); 76} 77 78function onDrop(event) 79{ 80 event.preventDefault(); 81 const index = event.dataTransfer.getData('text'); 82 const draggableElement = document.querySelectorAll(".employee_name")[index]; 83 const dropzone = event.currentTarget; 84 dropzone.appendChild(draggableElement); 85} 86</script> 87
試したこと
現状form_withを使っての保存を考えています。
form_with及びfields_forを使って保存するためのコード
f.hidden_field
に対してidを付与してその中にjsを使って入れ込むことができないかと試しましたがうまくいきませんでした。
補足情報(FW/ツールのバージョンなど)
Rubyのバージョンは6.0.0です。
また、コントローラーの記載が今回必要かどうかの判断ができなかったので、こちらに記載させていただきます。
ruby
1class ShiftController < ApplicationController 2 def index 3 end 4 5 def new 6 @shift = Shift.new 7 end 8 9 def create 10 @user_days = Day.where(shift_date: params[:date_save], ok_id: 2) 11 @num = [] 12 @user_days.each do |name| 13 @num << User.find(name.user_id) 14 end 15 end 16 17 def edit 18 end 19 20 private 21 def shift_params 22 params.require(:shift).merge(user_id: params[:user_id], ok_id: params[:ok_id], shift_date: params[:shift_date]) 23 end 24end 25
初学者にて質問に至らない点もあるかと思いますが、追記などはすぐに対応できるようにしますので、お答えいただけると幸いです。
あなたの回答
tips
プレビュー