Image manager for RailsAdmin and CKEditor.
- Add this line to your application's Gemfile:
gem 'rails_admin_image_manager'
- Run
$ bundle install
- Install RailsAdmin_ImageManager
$ rails generate rails_admin_image_manager:install
- Add the upload filepath to your .gitignore file
/public/rails_admin_image_manager
- Run migrations
$ rails db:migrate SCOPE=rails_admin_image_manager
- Install the image manager CKEditor plugin
mkdir -p app/assets/javascripts/ckeditor && touch app/assets/javascripts/ckeditor/config.js.erb
echo "//= require 'rails_admin_image_manager/ckeditor_plugin'" | cat - app/assets/javascripts/ckeditor/config.js.erb > temp && mv temp app/assets/javascripts/ckeditor/config.js.erb
- If you need to add the image manager button in a custom CKEditor config
CKEDITOR.editorConfig = function( config )
{
config.toolbar = [
[ 'Styles', 'Bold', 'Italic', 'Underline' ],
[ 'imageManager']
];
}
-
The
mount RailsAdminImageManager::Engine
route must appear before themount RailsAdmin::Engine
route in the app routes.rb file. -
If you need to explicitly specified the Files and Tags sections in RailsAdmin:
RailsAdmin.config do |config|
config.actions do
index do
only ['RailsAdminImageManager::Tag', 'RailsAdminImageManager::File']
end
end
end
The gem uses the RailsAdmin authentication and authorization methods.
- https://github.com/sferik/rails_admin/wiki/Authentication
- https://github.com/sferik/rails_admin/wiki/Authorization
Create the image foreign key in your db:
class CreateImageForeignKey < ActiveRecord::Migration[5.0]
def change
change_table :mymodel do |t|
t.integer :image_manager_file_id
end
add_foreign_key :mymodel, :image_manager_files, on_update: :cascade, on_delete: :restrict
end
end
Add the image relationship to your model:
class Mymodel < ApplicationRecord
# has_managed_file :attribute_name, :attribute_id, :options
has_managed_file :image_manager_file, :image_manager_file_id, mandatory: false
end
Add the image picker in RailsAdmin:
config.model Mymodel do
edit do
field :image_manager_file_id, :image_manager_picker do
config({
hidden_input: true,
paginates_per: 10
}) # Optionnal
end
end
end
To display the image in a Rails template:
<img src="<%= image_url @mymodel.image_manager_file.image.dynamic_url('100x100') %>">
When developping for the gem, assets need to be watch/compile. We are running a webpack/gulp setup ; to run it, just npm run start
at gem's root
- Mario Bouchard
- Louis-Philippe Dumas
The gem is available as open source under the terms of the MIT License.