socialforge/lib/rails_kindeditor/README.md

497 lines
16 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# Kindeditor for Ruby on Rails [![Gem Version](https://badge.fury.io/rb/rails_kindeditor.png)](http://badge.fury.io/rb/rails_kindeditor)
Kindeditor is a WYSIWYG javascript editor, visit http://www.kindsoft.net for details.
rails_kindeditor will helps your rails app integrate with kindeditor, includes images and files uploading.
<img src="https://github.com/Macrow/rails_kindeditor/raw/master/screenshots/rails_kindeditor.png" alt="rails_indeditor">
## Installation and usage
### Add this to your Gemfile
```ruby
gem 'rails_kindeditor'
```
### Run "bundle" command.
```bash
bundle
```
### Run install generator:
```bash
rails generate rails_kindeditor:install
```
notice: rails_kindeditor needs applications.js in your project.
### Rails4 in production mode
In Rails 4.0, precompiling assets no longer automatically copies non-JS/CSS assets from vendor/assets and lib/assets. see https://github.com/rails/rails/pull/7968
In Rails 4.0's production mode, please run 'rake kindeditor:assets', this method just copy kindeditor into public folder.
```bash
rake kindeditor:assets
```
### Usage:
```ruby
1. <%= kindeditor_tag :content, 'default content value' %>
# or <%= kindeditor_tag :content, 'default content value', :width => 800, :height => 300 %>
# or <%= kindeditor_tag :content, 'default content value', :allowFileManager => false %>
```
```ruby
2. <%= form_for @article do |f| %>
...
<%= f.kindeditor :content %>
# or <%= f.kindeditor :content, :width => 800, :height => 300 %>
# or <%= f.kindeditor :content, :allowFileManager => false %>
...
<% end %>
```
You can use kindeditor's initial parameters as usual, please visit http://www.kindsoft.net/docs/option.html for details.
additionally, rails_kindeditor provides one "simple_mode" parameter for render simple mode quickly.
<img src="https://github.com/Macrow/rails_kindeditor/raw/master/screenshots/simple_mode.png" alt="simple mode">
```ruby
kindeditor_tag :content, 'default content value', :simple_mode => true
f.kindeditor :content, :simple_mode => true
f.input :content, :as => :kindeditor, :input_html => { :simple_mode => true } # simple_form & formtastic
```
That's all.
### Work with turbolinks
rails_kindeditor will not load the scripts under the turbolinks, there's two way to solve this problem:
1.use "'data-no-turbolink' => true" when we need to load kindeditorthis will shut down the turbolinks in this page
```ruby
<%= link_to 'Edit', edit_article_path(article), 'data-no-turbolink' => true %>
```
2.load kindeditor manually, but you should specify the parameters again, include the textarea's id.
```coffeescript
# coffeescript code
$(document).on 'page:load', ->
if $('#article_content').length > 0
KindEditor.create '#article_content', "width":"100%", "height":300, "allowFileManager":true, "uploadJson":"/kindeditor/upload", "fileManagerJson":"/kindeditor/filemanager"
```
simple mode
```coffeescript
# coffeescript code
$(document).on 'page:load', ->
if $('#article_content').length > 0
KindEditor.create '#article_content',
"width":"100%",
"height":300,
"allowFileManager":true,
"uploadJson":"/kindeditor/upload",
"fileManagerJson":"/kindeditor/filemanager",
"items":["fontname","fontsize","|","forecolor","hilitecolor","bold","italic","underline","removeformat","|","justifyleft","justifycenter","justifyright","insertorderedlist","insertunorderedlist","|","emoticons","image","link"]
```
When you need to specify the owner_id
```ruby
f.kindeditor :content, owner_id: @article.id, data: {upload: kindeditor_upload_json_path(owner_id: @article.id), filemanager: kindeditor_file_manager_json_path}
```
```coffeescript
# coffeescript code
$(document).on 'page:load', ->
if $('#article_content').length > 0
KindEditor.create '#article_content',
"width" : "100%",
"height" : 300,
"allowFileManager" : true,
"uploadJson" : $('#article_content').data('upload'),
"fileManagerJson" : $('#article_content').data('filemanager')
```
### Include javascript files at bottom ? Not in the head tag ? How can I load kindeditor correctly ?
For some reasons, you includes javascript files at bottom in your template, rails_kindeditor provides a options for lazyload:
```ruby
<%= f.kindeditor :content, :window_onload => true %>
```
Warning: Kindeditor will load after all the objects loaded.
## SimpleForm and Formtastic integration
### simple_form:
```ruby
<%= form.input :content, :as => :kindeditor %>
# or
<%= form.input :content, :as => :kindeditor, :label => false, :input_html => { :width => 800, :height => 300 } %>
```
### formtastic:
```ruby
<%= form.input :content, :as => :kindeditor %>
# or
<%= form.input :content, :as => :kindeditor, :input_html => { :height => 300 } %>
```
## How to get kindeditor's content
```ruby
<%= form_for @article do |f| %>
<%= f.kindeditor :content, :editor_id => 'my_editor' %>
<% end %>
```
You can get content like this:
```javascript
// Javascript code
my_editor.html();
```
## Upload options configuration
When you run "rails generate rails_kindeditor:install", installer will copy configuration files in config/initializers folder.
You can customize some option for uploading.
```ruby
# Specify the subfolders in public directory.
# You can customize it , eg: config.upload_dir = 'this/is/my/folder'
config.upload_dir = 'uploads'
# Allowed file types for upload.
config.upload_image_ext = %w[gif jpg jpeg png bmp]
config.upload_flash_ext = %w[swf flv]
config.upload_media_ext = %w[swf flv mp3 wav wma wmv mid avi mpg asf rm rmvb]
config.upload_file_ext = %w[doc docx xls xlsx ppt htm html txt zip rar gz bz2]
# Porcess upload image size, need mini_magick
# before => after
# eg: 1600x1600 => 800x800
# 1600x800 => 800x400
# 400x400 => 400x400 # No Change
# config.image_resize_to_limit = [800, 800]
```
## Save upload file information into database(optional)
rails_kindeditor can save upload file information into database.
### Just run migration generate, there are two ORM options for you: 1.active_record 2.mongoid, default is active_record.
```bash
rails generate rails_kindeditor:migration
or
rails generate rails_kindeditor:migration -o mongoid
```
### The generator will copy model and migration to your application. When you are done, remember run rake db:migrate:
```bash
rake db:migrate
```
### Delete uploaded files automatically (only for active_record)
You can specify the owner for uploaded files, when the owner was destroying, all the uploaded files(belongs to the owner) will be destroyed automatically.
####1. specify the owner_id for kindeditor
```ruby
<%= form_for @article do |f| %>
...
<%= f.kindeditor :content, :owner_id => @article.id %>
...
<% end %>
```
```ruby
Warnning: the @article must be created before this scene, the @article.id should not be empty.
```
####2. add has_many_kindeditor_assets in your own model
```ruby
class Article < ActiveRecord::Base
has_many_kindeditor_assets :attachments, :dependent => :destroy
# has_many_kindeditor_assets :attachments, :dependent => :nullify
# has_many_kindeditor_assets :your_name, :dependent => :destroy
end
```
####3. relationship
```ruby
article = Article.first
article.attachments # => the article's assets uploaded by kindeditor
asset = article.attachments.first
asset.owner # => aritcle
```
### If you're using mongoid, please add 'gem "carrierwave-mongoid"' in your Gemfile
```ruby
gem 'carrierwave-mongoid'
```
## License
MIT License.
# Kindeditor for Ruby on Rails 中文文档
Kindeditor是国产的所见即所得javascript富文本编辑器, 访问 http://www.kindsoft.net 获取更多信息.
rails_kindeditor可以帮助你的rails程序集成kindeditor,包括了图片和附件上传功能,文件按照类型、日期进行存储。
## 安装及使用
### 将下面代码加入Gemfile
```ruby
gem 'rails_kindeditor'
```
### 运行"bundle"命令:
```bash
bundle
```
### 安装Kindeditor运行下面的代码
```bash
rails generate rails_kindeditor:install
```
注意: 在你的工程中需要有application.js文件。
### Rails4 in production mode
从Rails 4.0开始, precompiling assets不再自动从vendor/assets和lib/assets拷贝非JS/CSS文件. 参见 https://github.com/rails/rails/pull/7968
如果要使用Rails 4.0的生产模式,请运行'rake kindeditor:assets', 此方法可将kindeditor自动拷贝到你的public/assets目录.
```bash
rake kindeditor:assets
```
### 使用方法:
```ruby
1. <%= kindeditor_tag :content, 'default content value' %>
# or <%= kindeditor_tag :content, 'default content value', :width => 800, :height => 300 %>
# or <%= kindeditor_tag :content, 'default content value', :allowFileManager => false %>
```
```ruby
2. <%= form_for @article do |f| -%>
...
<%= f.kindeditor :content %>
# or <%= f.kindeditor :content, :width => 800, :height => 300 %>
# or <%= f.kindeditor :content, :allowFileManager => false %>
...
<% end -%>
```
你可以像往常那样使用kindeditor自身的初始化参数请访问 http://www.kindsoft.net/docs/option.html 查看更多参数。
另外rails_kindeditor还额外提供一个"simple_mode"参数以便快捷使用简单模式的kindeditor。
```ruby
kindeditor_tag :content, 'default content value', :simple_mode => true
f.kindeditor :content, :simple_mode => true
f.input :content, :as => :kindeditor, :input_html => { :simple_mode => true } # simple_form & formtastic
```
完毕!
### 如何在turbolinks下使用
rails_kindeditor在turbolinks下不会正常加载只有当页面刷新时才正常。turbolinks的机制就是这样的页面根本没刷新这和pjax是一样的所以kindeditor没加载很正常。
有两个办法可以解决:
1.在需要加载kindeditor的链接加入 'data-no-turbolink' => true 此时相当在这个页面于关闭turbolinks。
```ruby
<%= link_to 'Edit', edit_article_path(article), 'data-no-turbolink' => true %>
```
2.在turbolinks载入完毕后手动加载kindeditor不过所有参数都要设置而且需要知道并设定textarea的id。
```coffeescript
# coffeescript code
$(document).on 'page:load', ->
if $('#article_content').length > 0
KindEditor.create '#article_content', "width":"100%", "height":300, "allowFileManager":true, "uploadJson":"/kindeditor/upload", "fileManagerJson":"/kindeditor/filemanager"
```
simple模式也需要手动设定
```coffeescript
# coffeescript code
$(document).on 'page:load', ->
if $('#article_content').length > 0
KindEditor.create '#article_content',
"width":"100%",
"height":300,
"allowFileManager":true,
"uploadJson":"/kindeditor/upload",
"fileManagerJson":"/kindeditor/filemanager",
"items":["fontname","fontsize","|","forecolor","hilitecolor","bold","italic","underline","removeformat","|","justifyleft","justifycenter","justifyright","insertorderedlist","insertunorderedlist","|","emoticons","image","link"]
```
需要指定owner_id的方法
```ruby
f.kindeditor :content, owner_id: @article.id, data: {upload: kindeditor_upload_json_path(owner_id: @article.id), filemanager: kindeditor_file_manager_json_path}
```
```coffeescript
# coffeescript code
$(document).on 'page:load', ->
if $('#article_content').length > 0
KindEditor.create '#article_content',
"width" : "100%",
"height" : 300,
"allowFileManager" : true,
"uploadJson" : $('#article_content').data('upload'),
"fileManagerJson" : $('#article_content').data('filemanager')
```
### 把javascript放在模板最下方不放在head里面如何正确加载kindeditor
有时候为了加快页面载入速度也许你会把javascript引用放在template的底部rails_kindeditor提供了一个参数可以确保正常加载
```ruby
<%= f.kindeditor :content, :window_onload => true %>
```
警告Kindeditor会在页面所有的内容加载完毕后才进行加载所以需谨慎使用
## SimpleForm与Formtastic集成
### simple_form:
```ruby
<%= form.input :content, :as => :kindeditor, :label => false, :input_html => { :width => 800, :height => 300 } %>
```
### formtastic:
```ruby
<%= form.input :content, :as => :kindeditor %>
<%= form.input :content, :as => :kindeditor, :input_html => { :height => 300 } %>
```
## 如何获取kindeditor的内容
```ruby
<%= form_for @article do |f| %>
<%= f.kindeditor :content, :editor_id => 'my_editor' %>
<% end %>
```
可通过下面的Javascript代码获取内容:
```javascript
// Javascript code
my_editor.html();
```
## 上传图片及文件配置
当你运行"rails generate rails_kindeditor:install"的时候安装器会将配置文件拷贝到config/initializers文件夹。
你可以配置以下上传选项:
```ruby
# 指定上传目录目录可以指定多级都存储在public目录下.
# You can customize it , eg: config.upload_dir = 'this/is/my/folder'
config.upload_dir = 'uploads'
# 指定允许上传的文件类型.
config.upload_image_ext = %w[gif jpg jpeg png bmp]
config.upload_flash_ext = %w[swf flv]
config.upload_media_ext = %w[swf flv mp3 wav wma wmv mid avi mpg asf rm rmvb]
config.upload_file_ext = %w[doc docx xls xlsx ppt htm html txt zip rar gz bz2]
# 处理上传文件需要mini_magick
# 处理以前 => 处理以后
# eg: 1600x1600 => 800x800
# 1600x800 => 800x400
# 400x400 => 400x400 # 图片小于该限制尺寸则不作处理
# config.image_resize_to_limit = [800, 800]
```
## 将上传文件信息记录入数据库(可选)
rails_kindeditor 可以将上传文件信息记录入数据库,以便扩展应用.
### 运行下面的代码有两项选项1.active_record 2.mongoid默认是active_record。
```bash
rails generate rails_kindeditor:migration
or
rails generate rails_kindeditor:migration -o mongoid
```
### 运行下面的代码:
```bash
rake db:migrate
```
### 自动删除上传的文件(仅在active_record下工作)
你可以为上传的文件指定归属,比如一名用户,或者一篇文章,当用户或者文章被删除时,所有属于该用户或者该文章的上传文件将会被自动删除。
####1. 为kindeditor指定owner_id
```ruby
<%= form_for @article do |f| %>
...
<%= f.kindeditor :content, :owner_id => @article.id %>
...
<% end %>
```
```ruby
警告: @article应该事先被创建@article.id不应该是空的
```
####2. 在你自己的模型里加入has_many_kindeditor_assets
```ruby
class Article < ActiveRecord::Base
has_many_kindeditor_assets :attachments, :dependent => :destroy
# has_many_kindeditor_assets :attachments, :dependent => :nullify
# has_many_kindeditor_assets :your_name, :dependent => :destroy
end
```
####3. 相互关系
```ruby
article = Article.first
article.attachments # => the article's assets uploaded by kindeditor
asset = article.attachments.first
asset.owner # => aritcle
```
### 如果你使用的是mongoid, 请在你的Gemfile里加入'gem "carrierwave-mongoid"'
```ruby
gem 'carrierwave-mongoid'
```
## License
MIT License.