#現在エラーが出ているファイル
baggage_paramsメソッドの記述、newアクションとcreateアクションの記述がbuildを使ったものかもしれないです。
class Admin::BaggagesController < ApplicationController before_action :if_not_admin before_action :set_baggage, only: [:show, :edit, :destroy] def index if current_user.admin? # @baggages = Baggage.search(params[:search]) @search = User.ransack(params[:q]) #:qは入力したクエリのq @users = @search.result end end def new if current_user.admin? @baggage = Baggage.new end end def create # @baggage = current_user.baggages.build(baggage_params) # @baggage = Baggage.new.(user_id: @user.id) @baggage = Baggage.new(baggage_params)<--この、行を指してエラーが出ている状態です if @baggage.save redirect_to pages_path(@baggage) else render :new end end def edit end def destroy end def show end private def if_not_admin redirect_to root_path unless current_user.admin?#管理者ユーザー以外が特定のアクションを実行しようとした場合トップページにリダイレクトされる end def set_baggage @baggage = Baggage.find(params[:id])#edit, show, destroy などのアクションで使用する変数をセットします。 end def baggage_params params.require(:baggage).permit( :type,:storage_period, :code, ).merge(user_id:[@q]) end end
#遷移元のファイル(admin/baggages/index.html.haml)
= search_form_for @search, url: admin_baggages_url do |f| = f.label :name_cont, "名前を入力してください" = f.search_field :name_cont = f.submit "検索" .table .thead %tr %th= sort_link(@search, :name)#resultさせてる部分とリンク %th= sort_link(@search, :address) .tbody - @users.each do |user|#controllerの「@users = @search.result」検索したものを"返す" %tr -# %td= link_to user.name, new_admin_baggage_url(@q, :'q[user_id_eq]' => "#{user.id}") %td= user.name %td= user.address %td= link_to "New", new_admin_baggage_url(@q, :'q[user_id_eq]' => "#{user.id}")
#遷移先のファイル(admin/baggages/new.html.haml)
= f.hidden_field :user_id, :value => @q(params[:id])の行でuser_idに値が渡せておらず、空で送信されてます
.wrapper .disply = form_for @baggage ,url: admin_baggages_path do |f| .baggage .baggage__box %span 荷物の種類 = f.select :type, [["なまもの", "なまもの"], ["チルド", "チルド"], ["冷凍", "冷凍"], ["その他", "その他"]], include_blank: "選択して下さい" .baggage__box %span 保管期限 = f.text_field :storage_period, class: "baggage_text" , placeholder: '例)7' %span 日 .baggage__box %span 追跡番号 = f.text_field :code, class: "baggage_text", placeholder: '123456789012' = f.hidden_field :user_id, :value => @q(params[:id])<--この部分で値が渡せていません = f.submit 'SEND', class: "baggage__send"
明らかに実装出来ていない所はコードの横に <-- のマークを付けておきました
>良い方法ありますか?
ご自身が何か思いついている前提であればその内容とやってみたことを記載してください。
何も前提がないのでしたら、まず自身で考え、やってみてください。
問題・課題が明確になっていません。
ご指摘、ありがとうございます。
gem ransackを使って検索したユーザーの、userテーブルのidパラメーターを渡したlinkを、遷移先の新規入力(newアクション)ページに遅れてる?様な所まで進めた状態での質問を送らせていただきました
その状態が分かる内容になっていないので、質問本文に追記願います
・検索ページからの遷移元のコード("#{user.id}"のuserはeach文のユーザーデータの変数です)
%td= link_to "New", new_admin_baggage_url(@q, :'q[user_id_eq]' => "#{user.id}")
・user_idのフォーム
= f.hidden_field :user_id, :value => @q(params[:id])
paramsをみる限り、現在user_idが空の状態で送られています
質問本文に追記願います。
こちらはあくまで「質問への追記修正」のコメント欄です。質問は編集できるのでこちらにコメントするのではなく、質問を編集して返していただければと。
(その際、コードはマークダウン利用してください)
こちらのコメント欄はデフォルト非表示なので質問本文との関連性は薄くなります。
度々のフィードバック感謝です
質問の方、修正いたしました
回答1件
あなたの回答
tips
プレビュー