Вот так, я думаю, это должно выглядеть, я немного изменил вашу форму. Это также предполагает, что вы не проводите никакой проверки объектов настройки, проверка и отображение ошибок будет непростым делом с несколькими экземплярами класса Setting в одной форме, но это можно сделать. Мой пример не будет отображать никаких ошибок.
конфиг / routes.rb
map.namespace(:admin) do |admin|
admin.resources :settings, :collection => { :set => :put }
end
приложение / контроллеры / администратор / settings_controller.rb
def set
#this is what I think your action should do
params[:settings].each do |setting|
@setting = Setting.find(setting[:id])
@setting.update_attributes(setting)
end
redirect_to admin_settings_path
end
приложение / просмотров / админ / Настройки / index.html.erb
<% form_tag set_admin_settings_path, :method => :put do %>
<ol>
<% for setting in @settings %>
<li class="field">
<label>
<%= setting.setting_name.humanize %>
</label>
<!-- settings[][field_name] will group the settings objects in params -->
<%= hidden_field_tag("setting_#{setting.id}_id",
setting.id,
:name => 'settings[][id]') %>
<%= text_field_tag("setting_#{setting.id}_setting_value",
setting.setting_value,
:name => 'settings[][setting_value]) %>
</li>
<% end %>
<li class="submit">
<%= submit_tag "Update settings" %>
</li>
</ol>
<% end %>