Editor.js integration for Rails.
Provides some helpers and a little bit of Javascript to integrate the Editor.js block model into a Rails application.
Add the editorjs-rails
gem to your Gemfile
:
gem "editorjs-rails", github: "inaudito/editorjs-rails"
Migrate your database:
rails editorjs:install:migrations
rails db:migrate
Mount Editorjs::Engine
in your routes.rb
:
mount Editorjs::Engine, at: "/editorjs"
Add the included script to your application layout:
<%= javascript_include_tag "editorjs-rails", "data-turbo-track": "reload", defer: true, type: "module" %>
Add an attribute to your model using has_text
:
class MyModel < ApplicationRecord
has_text :my_awesome_text
end
Then use the editorjs_text_area
form helper in your views:
<%= form_with model: @my_model do |form| %>
<%= form.editorjs_text_area :my_awesome_text %>
<% end %>
Use to_html
to render your content:
<%= @my_model.my_awesome_text.to_html %>
First, define window.EditorJS.Rails.tools
following the Editor.js convention:
import "@editorjs/paragraph";
window.EditorJS.Rails = {
tools: {
paragraph: Paragraph
}
};
Then register your new block type:
class ParagraphBlock < Editorjs::Text::Block
attr_reader :text
def initialize(**options)
super
@text = @data["text"]
end
def to_html
tag.p(@text.html_safe)
end
end
Editorjs::Text::Content.register_block_type :paragraph, ParagraphBlock
Shorthand | Class | Plugin |
---|---|---|
paragraph |
Editorjs::Text::Block::Paragraph |
@editorjs/paragraph |
header |
Editorjs::Text::Block::Header |
@editorjs/header |
image |
Editorjs::Text::Block::Image |
@editorjs/image |
list |
Editorjs::Text::Block::List |
@editorjs/nested-list |
quote |
Editorjs::Text::Block::Quote |
@editorjs/quote |
raw |
Editorjs::Text::Block::Raw |
@editorjs/raw |
delimiter |
Editorjs::Text::Block::Delimiter |
@editorjs/delimiter |
strikethrough |
@sotaproject/strikethrough |