3
votes

I'm using the ckeditor (https://github.com/galetahub/ckeditor) gem on Rails 3.2.11 / Ruby 1.9.3.

I've been getting this JS error after I do rake assets:precompile on production environment (deployed to Heroku)

Uncaught TypeError: Object #<Object> has no method 'apply' 

I don't know if it's relevant, but I've traced the error (using Chrome's webdev tools) to a block that starts:

CKEDITOR.plugins.add("basicstyles", ...)

which I assume is the plugin responsible for adding the bold, italic, underline, and other such font style buttons to the toolbar.

The textarea is still showing without the CKEditor UI.

I'm using the latest version (4.0.4) from rubygems.

I have this in my application.js:

//= require 'ckeditor/init'
//= require 'ckeditor/config'

I have a custom config file in app/assets/ckeditor/config.js and have two custom plugins in app/assets/ckeditor/plugins/.

I've also tested it locally using RAILS_ENV=production and also not working.

2
You have the require statements in your Gemfile?AlexBrand
Sorry, bout that. Thanks for pointing it out. Yes, it should have said, "application.js"gillian.dugay

2 Answers

1
votes

I found what's causing the issue. It's an old uglifier version. Moving it from ~> 1.0.3 to >= 1.0.3 (which updated to 2.1.1) solved the issue.

0
votes

A couple of things that may help

Those //= require lines need to go in your application.js file, your Gemfile should just have gem 'ckeditor'.

also it should be :

app/assets/javascripts/ckeditor/config.js and app/assets/javascripts/ckeditor/plugins

rather than

app/assets/ckeditor/config.js and app/assets/ckeditor/plugins

Finally you can use

<%= f.input :content, :input_html => {:class => 'ckeditor', :rows => "10"}%>

in your views. Note that this is a SimpleForm input.

I used the ckeditor-rails gem and everything went pretty smoothly for me.

Hope it helps.