编辑表单复选框,radio和trix编辑器未在ActiveAdmin

时间:2017-02-10 14:14:03

标签: ruby-on-rails ruby ruby-on-rails-4 activeadmin formtastic

我有一个包含复选框,trix编辑器,单选按钮和文本字段的表单。当我在管理界面中编辑记录时,将显示包含所有文本字段的表单。我无法看到trix编辑器,复选框和单选按钮。

我知道as: :radioas: :check_boxes以及as: :trix_editor应该有效,但是他们没有预先填充已保存的值

这是我的jobposting.rb文件。

任何帮助都将非常感激。

form do |f|
    f.inputs "New Job Posting" do
      f.input :title
      f.input :description, as: :trix_editor
      f.input :how_to_apply, as: :trix_editor
      f.input :job_type, as: :radio
      f.input :city
      f.input :user_id
      f.input :categories, as: :check_boxes

      f.input :publish


    end
    f.actions
  end

,表单如下所示

enter image description here

它没有显示应该有trix编辑器的字段(描述,如何应用)。对于广播(作业类型)和复选框(类别)字段,其显示简单的是和否..其中这些字段的实际值为enter image description here

EDITED

Started GET "/admin/job_postings/3/edit" for ::1 at 2017-02-11 12:41:22 +0530
Processing by Admin::JobPostingsController#edit as HTML
  Parameters: {"id"=>"3"}
  AdminUser Load (0.4ms)  SELECT  "admin_users".* FROM "admin_users" WHERE "admin_users"."id" = $1  ORDER BY "admin_users"."id" ASC LIMIT 1  [["id", 1]]
  JobPosting Load (0.3ms)  SELECT  "job_postings".* FROM "job_postings" WHERE "job_postings"."id" = $1 LIMIT 1  [["id", 3]]
  CACHE (0.0ms)  SELECT  "job_postings".* FROM "job_postings" WHERE "job_postings"."id" = $1 LIMIT 1  [["id", "3"]]
  Rendered /Users/KrishnaTeja/.rbenv/versions/2.2.3/lib/ruby/gems/2.2.0/bundler/gems/activeadmin-2bb5021f81c2/app/views/active_admin/resource/edit.html.arb (270.1ms)
Completed 500 Internal Server Error in 367ms (ActiveRecord: 7.4ms)

ActionView::Template::Error (undefined method `categories' for #<Class:0x007ffdd084e420>):
    1: insert_tag renderer_for(:edit)
  app/admin/job_postings.rb:26:in `block (3 levels) in <top (required)>'
  app/admin/job_postings.rb:18:in `block (2 levels) in <top (required)>'


  Rendered /Users/KrishnaTeja/.rbenv/versions/2.2.3/lib/ruby/gems/2.2.0/gems/actionpack-4.2.7.1/lib/action_dispatch/middleware/templates/rescues/_source.erb (16.6ms)
  Rendered /Users/KrishnaTeja/.rbenv/versions/2.2.3/lib/ruby/gems/2.2.0/gems/actionpack-4.2.7.1/lib/action_dispatch/middleware/templates/rescues/_trace.html.erb (7.9ms)
  Rendered /Users/KrishnaTeja/.rbenv/versions/2.2.3/lib/ruby/gems/2.2.0/gems/actionpack-4.2.7.1/lib/action_dispatch/middleware/templates/rescues/_request_and_response.html.erb (1.8ms)
  Rendered /Users/KrishnaTeja/.rbenv/versions/2.2.3/lib/ruby/gems/2.2.0/gems/actionpack-4.2.7.1/lib/action_dispatch/middleware/templates/rescues/template_error.html.erb within rescues/layout (115.2ms)

enter image description here enter image description here

这是我views/job_postings/_form.html.erb 如果你检查类别字段,那么它不是来自任何一个有数组的表,而是迭代它。

<%= form_for @job_posting do |f| %>
<% if @job_posting.errors.any? %>
        <div id="errors">
            <h2><%= pluralize(@job_posting.errors.count, "error") %> prevented this post from saving:</h2>
            <ul>
                <% @job_posting.errors.full_messages.each do |msg| %>
                    <li><%= msg %></li>
                <% end %>
            </ul>
        </div>
    <% end %>

<p>
    <%= f.label :title %>
    <%= f.text_field :title %>
</p>

<p>
    <%= f.label :description %>

   <%= f.trix_editor :description %>

</p>
<p>
    <%= f.label :how_to_apply %>
    <%= f.trix_editor :how_to_apply %>
</p>
<p>
    <%= f.label :categories %>

    <% [ 'Front End', 'Back End', 'Others'].each do |category| %>
      <%= label_tag "job_posting_categories_#{category}", category %>

      <%= check_box_tag "job_posting[categories][]", category, checked(category), id: "job_posting_categories_#{category}" %> 


    <% end %>

</p>
<p>
    <%= f.label :job_type %>
    <% [ 'FullTime', 'Contract', 'PartTime', 'Freelance', 'Intern'].each do |job_type| %>
         <%= f.radio_button 'job_type', job_type %>
          <%= job_type.humanize %>
    <% end %>

</p>
<p>
    <%= f.label :city %>
    <%= f.text_field :city %>
</p>
    <%= f.submit "Post Job" %>


<% end %>

2 个答案:

答案 0 :(得分:1)

<强>解决

ActiveAdmin.register JobPosting do

# See permitted parameters documentation:
# https://github.com/activeadmin/activeadmin/blob/master/docs/2-resource-customization.md#setting-up-strong-parameters
#
permit_params :title, :description,:how_to_apply, :job_type ,:city,:user_id,{ categories: []}, :publish
#
# or
#
# permit_params do
#   permitted = [:permitted, :attributes]
#   permitted << :other if params[:action] == 'create' && current_user.admin?
#   permitted
# end


form do |f|
    inputs "New Job Posting" do

      input :title
      input :description
      input :how_to_apply
      input :job_type, as: :radio, collection: [ 'FullTime', 'Contract', 'PartTime', 'Freelance', 'Intern']
      input :city
      input :user, member_label: :email
      input :categories, as: :check_boxes, collection: ['Front End','Back End','Others'].map { |e| [e, e,{checked: f.object.categories.include?(e)}] }

      input :publish


    end
    actions
  end


end

答案 1 :(得分:0)

f.input :categories, as: :check_boxes, collection: f.object.categories 似乎与activeadmin不兼容,所以我不确定你是否能够使用它。对于其他人,您需要包含要显示的集合,否则它似乎默认为是/否框。所以像这样:

  form do |f|
    inputs "New Job Posting" do
      input :title
      input :description
      input :how_to_apply
      input :job_type, as: :radio
      input :city
      input :user_id
      input :categories, as: :check_boxes, collection: f.object.categories
      input :publish
    end
    actions
  end

这应该让主动管理员知道您要使用类别可用的选项来填充复选框。

编辑:

请改为尝试:

  form do |f|
    inputs "New Job Posting" do
      input :title
      input :description
      input :how_to_apply
      input :job_type, as: :radio
      input :city
      input :user_id
      input :categories, as: :check_boxes, collection: JobPosting.categories
      input :publish
    end
    actions
  end

甚至:

<preference name="android-targetSdkVersion" value="20"/>