Ryan Bates が、Javascript を使用して親オブジェクト フォーム内でネストされたオブジェクトを動的に追加または削除する方法を説明している、素晴らしい複雑なフォームの railscast を見てきました。
Haml Formtastic で動作するようにこれらのメソッドをどのように変更する必要があるかについて、何かアイデアを持っている人はいますか?
コンテキストを追加するために、現在直面している問題の簡略版を次に示します。
# Teacher フォーム (サブジェクト フォームがネストされている) [私のアプリケーションから]
- semantic_form_for(@teacher) do |form|
- form.inputs do
= form.input :first_name
= form.input :surname
= form.input :city
= render 'subject_fields', :form => form
= link_to_add_fields "Add Subject", form, :subjects
# 個人件名フォームの一部 [私の申請書から]
- form.fields_for :subjects do |ff|
#subject_field
= ff.input :name
= ff.input :exam
= ff.input :level
= ff.hidden_field :_destroy
= link_to_remove_fields "Remove Subject", ff
# アプリケーション ヘルパー (Railscasts からそのまま)
def link_to_remove_fields(name, f)
f.hidden_field(:_destroy) + link_to_function(name, "remove_fields(this)")
end
def link_to_add_fields(name, f, association)
new_object = f.object.class.reflect_on_association(association).klass.new
fields = f.fields_for(association, new_object, :child_index => "new_#{association}") do |builder|
render(association.to_s.singularize + "_fields", :f => builder)
end
link_to_function(name, h("add_fields(this, \"#{association}\", \"#{escape_javascript(fields)} \")"))
end
#Application.js (Railscasts からそのまま)
function remove_fields(link) {
$(link).previous("input[type=hidden]").value = "1";
$(link).up(".fields").hide();
}
function add_fields(link, association, content) {
var new_id = new Date().getTime();
var regexp = new RegExp("new_" + association, "g")
$(link).up().insert({
before: content.replace(regexp, new_id)
});
}
実装の問題は、JavaScript メソッドにあるようです。Formtastic フォームの DOM ツリーは、通常の Rails フォームとは大きく異なります。
この質問がオンラインで何度か出されているのを見たことがありますが、まだ答えが出ていません。
ジャック