我需要一个简单的表单来添加一系列电话号码。
ActiveAdmin.register Did do
# ..
collection_action :add_range, :method => :get do
end
collection_action :add_range, :method => :post do
end
end
<%= semantic_form_for [:admin, :dids, :add_range] do |f| %>
<%= f.inputs :start, :end %>
<%= f.buttons :commit %>
<% end %>
以上内容因“符号:类的未定义方法`model_name'”而失败。
如何定义这样一个不直接使用对象的表单?
答案 0 :(得分:1)
试过,这样可行:
<%= semantic_form_for :range, :url => add_range_admin_dids_path do |f| %>
<%= f.inputs :start, :end %>
<%= f.buttons :commit %>
<% end %>
然后在params [:range]
中找到已发布的参数答案 1 :(得分:0)
我很确定您需要在致电semantic_form_for
时使用模型。由于您的操作是集合操作,因此它不会对特定DID执行操作,因此您要创建的模型是什么?范围模型?如果是这种情况,你应该只有:
<%= semantic_form_for [:admin, @range] do |f| %>
<% ... %>
<%= f.buttons :commit
<% end %>
当然@range
应该在控制器中初始化为Range.new
。
编辑:实现有点迟,你不想使用一个对象。在documentation中,它表示您可以使用semantic_form_for :login
,但它可能不适用于嵌套/命名空间表单。您可能需要使用url
或类似内容指定:url => admin_add_range_dids_path
。只需检查rake routes
即可找到正确的命名。不确定ActiveAdmin或Formtastic是否正在调用该模型,因此仍然可能无法正常工作,但值得尝试。
答案 2 :(得分:0)
我遇到类似的情况,我需要自定义表单操作属性。因此,我发现实现此目的的最佳方法是在相应视图的文件夹中创建部分表单。
首先告诉您的资源您将使用自定义表单,因此请将此行添加到资源文件中:
# app/admin/organizations.rb
form partial: "form"
现在,您可以使用Arbre Components创建部分,如下例所示:
# app/views/admin/organizations/_form.html.arb
active_admin_form_for [:admin, resource] do |f|
tabs do
tab 'General Configuration' do
f.inputs 'Organization Details' do
admin_accounts = User.with_role(:admin).order('email ASC')
site_collection = Site.where("subdomain <> ''").map { |site| ["#{site.subdomain}", site.id ]}
f.input :name
f.input :kind, :as => :enum
f.input :carereceiver_kind, :as => :enum
f.input :account_manager, :as => :select ,:collection => admin_accounts
f.input :site_id, as: :select ,collection: site_collection
f.input :office_phone
f.input :office_fax
f.input :office_address
f.input :company_logo, :as => :file
f.input :letterhead
f.input :base_url, label: 'BASE URL'
f.input :dynamics_url, label: 'DYNAMICS URL'
f.input :genoa_site_id, label: 'GENOA SITE ID'
end
f.inputs 'Organization Settings' do
f.input :demo_account
f.input :appointment_not_started_notifications_enabled
f.input :erx_enabled
f.input :patients_can_book_appointments
f.input :new_providers_can_manage_their_own_availability_by_default
f.input :clarity_enabled
f.input :whitelist_enabled
f.input :bed_form_enabled
f.input :patient_email_required, label: 'Require patient email addresses'
f.input :patient_credit_card_required, label: 'Require patient credit card information'
f.input :enable_patient_survey, label: 'Enable patient survey'
f.input :enable_provider_survey, label: 'Enable provider survey'
f.input :rcopia4_enabled, label: 'Rcopia 4 enabled'
f.input :share_notes_across_providers_enabled
f.input :d2c_mode
f.input :sso_login_only
f.input :allow_invited_patients_to_complete_profile
f.input :allow_overlapping_appointments, as: :select
f.input :media_mode, :as => :enum
end
f.inputs('Organization Contacts', { class: 'organization_contacts_section' }) do
saved_contacts = f.object.organization_contacts.count
n = 5 - saved_contacts.to_i
n.times do
f.object.organization_contacts.build
end
contact_counter = 0
f.fields_for :organization_contacts do |m|
contact_counter = contact_counter + 1
m.inputs "Contact #{contact_counter}" do
m.input :name, placeholder: 'Name'
m.input :title, placeholder: 'Title'
m.input :email, placeholder: 'Email'
m.input :phone_number, placeholder: 'Phone Number'
end
end
end
end
tab 'Appointment Parser Configuration' do
f.inputs 'Appointment Parser Configuration' do
f.input :appointment_parsers, as: :select, input_html: { multiple: true }
end
end
tab 'EMR Settings' do
f.inputs 'Settings' do
f.input :emr_integrated, label: 'Enable EMR integration'
f.input :emr_processor_type, as: :select, collection: Organization::AVAILABLE_EMR_PROCESSORS
f.input :send_to_emr, label: 'Enable integration from 1DW to EMR'
f.input :receive_from_emr, label: 'Enable integration from EMR to 1DW'
end
end
tab 'Athena EMR Settings' do
f.inputs 'Settings' do
f.input :athena_practice_id, label: 'Athena Practice ID', input_html: { disabled: !f.object.has_athena_processor? }
f.input :athena_department_number, label: 'Athena Department ID', input_html: { disabled: !f.object.has_athena_processor? }
end
end
end
f.actions
end
正如您在admin_organization_path
中看到的那样,您可以将网址指向您想要的任何其他网址,同时您也可以自定义method
以发送表单。
另外,请确保对
resource
块使用active_admin_form_for
,因为如果您尝试使用@organization
之类的内容,则会出现错误。每次配置相应的模型关系时,表单都包含将嵌套资源添加到主体资源的可能方法。
有了它,它应该工作正常。 我希望它对其他人有用。