web-dev-qa-db-ja.com

Activeadminを使用したファイルのアップロードRails paperclipを使用

アクティブ管理者をRailsアプリケーションバックエンドとして使用します。ファイルをアップロードしたいのですが、この機能を実現するにはどうすればよいですか?

41
Sebastien

アクティブな管理でPaperclipを使用する方法を見つけました。

モデル「イベント」にこのコードを追加しました。

has_attached_file :map, :styles => { :medium => "238x238>", 
                                   :thumb => "100x100>"
                                 }

そして、私は私の管理者モデルのためにこれをしました:

ActiveAdmin.register Event do
 form :html => { :enctype => "multipart/form-data" } do |f|
   f.inputs "Details" do
    f.input :continent
    f.input :event_type
    f.input :name
    f.input :title
    f.input :content
    f.input :date_start, :as => :date
    f.input :date_end, :as => :date
    f.input :place
    f.input :map, :as => :file
    f.input :image, :as => :file, :hint => f.template.image_tag(f.object.image.url(:medium))
    f.input :userfull_info
    f.input :price
    f.input :phone, :as => :phone
    f.input :website, :as => :url
  end
  f.buttons
 end
end

インデックスページで使用するには、次を使用する必要があります。

column "Image" do |event|
    link_to(image_tag(event.image.url(:thumb), :height => '100'), admin_event_path(event))
  end
  default_actions
end
75
Sebastien

Rails 4.1およびPaperclip 4.1で動作しました:

モデル

class Hotel < ActiveRecord::Base

has_attached_file :thumbnail, :styles => { :medium =>     "300x300#", :thumb => "200x200#" }
validates_attachment :thumbnail, content_type: { content_type:     ["image/jpg", "image/jpeg", "image/png"] }

end

管理者モデル

ActiveAdmin.register Hotel do

permit_params :name, :description, :price, :thumbnail

form do |f|
  f.inputs "Project Details" do
    f.input :name
    f.input :thumbnail, :required => false, :as => :file
    # Will preview the image when the object is edited
  end
  f.actions
 end

show do |ad|
  attributes_table do
    row :name
    row :thumbnail do
      image_tag(ad.thumbnail.url(:thumb))
    end
    # Will display the image on show object page
  end
 end
end
13
kokemomuke

Rails 3.0.1と次のコードを使用しています

f.input :image, :hint => "current image: #{f.template.image_tag(f.object.image.url(:thumb))}" 

文字列を返します。ソリューションを検索した後、私はそれを見つけました。

f.input :image, :hint => f.template.image_tag(f.object.image.url(:thumb))

オブジェクトを直接送信し、htmlに画像を返します

6
mmarqueti

ActiveAdminの最新バージョン&Rails 4ファイルフィールドを表示するには、以下のコードを使用する必要があります

以前はf.input:uploads、:as =>:fileを使用していました

ActiveAdmin.register Project do
  permit_params :name, :uploads


  form multipart: true do |f|
    f.inputs "Project Details" do
      f.input :name
      f.input :uploads, required: false
    end
    f.actions
  end

end
5
Amal Kumar S