dynamic_fields is a rails engine, written for dynamically generating nested model form fields. You can use it with the built in form helpers or any other form builder gem like 'simple_form'. It will keep the structure and style from them. It is currently only support rails 3.1+
-
Add the gem to your Gemfile and run
bundle install
to make sure the gem gets installed.gem 'dynamic_fields'
-
Add this line to
app/assets/javascripts/application.js
. Be sure to include this line after jQuery and jQuery UJS Adapter.//= require dynamic_fields
-
(Optional) Add this line to
app/assets/stylesheets/application.css
. This is only used to style the remove link for the nested fields. Most of the time you will need to style it according to your layout.*= require dynamic_fields
Your model need to setup to use accepts_nested_attributes_for
with :allow_destroy => true
option, in order for the nested form to work
In your form, you can use the dynamic_fields_wrapper_for
helper method to wrap your nested form fields.
Here is an example using the simple_form builder in haml:
#more_qa
Add More QA
#qas
= f.simple_fields_for :qas do |qa|
= dynamic_fields_wrapper_for(qa) do
= qa.input :question, :input_html => {:class => 'span6'}
= qa.input :answer, :input_html => {:class => 'span6'}
Add this to your js file
jQuery ->
$('#more_qa').click ->
$("#qas").cloneFields()
$("body").delegate ".remove_dynamic_field", 'click', ->
$(this).removeFields()
return false
That is all you have to do to get it to work.
The default wrapper node generate from dynamic_fields_wrapper_for
is "fieldset" with class "item".
Also the default link text to remove the fields is remove_link_text
.
You can override them by passing a hash to the helper method like this:
= dynamic_fields_wrapper_for(qa, :node => 'div', :class => 'nested_field', :remove_link_text => 'remove') do
= your code block
If you override the :class option, you will need to apply that to the Javascript as well:
$("#qas").cloneFields({
itemWrapper: ".nested_field"
})
The removeFields
method may accept a hash of options as parameter. To change the confirmation message,
set the confirmationMessage
value in the options hash. The default confirmation message is "Are you sure?".
$("body").delegate ".remove_dynamic_field", 'click', ->
$(this).removeFields({confirmationMessage: 'Deleting a record may have dire consequences; are you sure?'})
...
If you want to take a look at an example, you can checkout the dummy app that used for testing.
This project uses MIT-LICENSE.