diff options
author | Sam Stephenson <sam@37signals.com> | 2018-02-07 18:26:19 -0600 |
---|---|---|
committer | Sam Stephenson <sam@37signals.com> | 2018-02-07 18:26:19 -0600 |
commit | 68d350ddacedf604717f0d1074d7624fa57757c2 (patch) | |
tree | a01852130448e37368ed2fd4af7e930e6c2cd0f2 /lib/active_text/attachables | |
parent | e22ba227a694b8426e69dbce640c5b0e4f39f574 (diff) | |
download | rails-68d350ddacedf604717f0d1074d7624fa57757c2.tar.gz rails-68d350ddacedf604717f0d1074d7624fa57757c2.tar.bz2 rails-68d350ddacedf604717f0d1074d7624fa57757c2.zip |
Initial import from BC3 RichText
Diffstat (limited to 'lib/active_text/attachables')
-rw-r--r-- | lib/active_text/attachables/content_attachment.rb | 36 | ||||
-rw-r--r-- | lib/active_text/attachables/missing_attachable.rb | 11 | ||||
-rw-r--r-- | lib/active_text/attachables/remote_image.rb | 44 |
3 files changed, 91 insertions, 0 deletions
diff --git a/lib/active_text/attachables/content_attachment.rb b/lib/active_text/attachables/content_attachment.rb new file mode 100644 index 0000000000..316d7e304a --- /dev/null +++ b/lib/active_text/attachables/content_attachment.rb @@ -0,0 +1,36 @@ +module ActiveText + module Attachables + class ContentAttachment + include ActiveModel::Model + + def self.from_node(node) + if node["content-type"] + if matches = node["content-type"].match(/vnd\.rubyonrails\.(.+)\.html/) + attachment = new(name: matches[1]) + attachment if attachment.valid? + end + end + end + + attr_accessor :name + validates_inclusion_of :name, in: %w( horizontal-rule ) + + def attachable_plain_text_representation(caption) + case name + when "horizontal-rule" + " ┄ " + else + " " + end + end + + def to_partial_path + "active_text/attachables/content_attachment" + end + + def to_trix_content_attachment_partial_path + "active_text/attachables/content_attachments/#{name.underscore}" + end + end + end +end diff --git a/lib/active_text/attachables/missing_attachable.rb b/lib/active_text/attachables/missing_attachable.rb new file mode 100644 index 0000000000..94a095ce09 --- /dev/null +++ b/lib/active_text/attachables/missing_attachable.rb @@ -0,0 +1,11 @@ +module ActiveText + module Attachables + module MissingAttachable + extend ActiveModel::Naming + + def self.to_partial_path + "active_text/attachables/missing_attachable" + end + end + end +end diff --git a/lib/active_text/attachables/remote_image.rb b/lib/active_text/attachables/remote_image.rb new file mode 100644 index 0000000000..0624b5564d --- /dev/null +++ b/lib/active_text/attachables/remote_image.rb @@ -0,0 +1,44 @@ +module ActiveText + module Attachables + class RemoteImage + extend ActiveModel::Naming + + class << self + def from_node(node) + if node["url"] && content_type_is_image?(node["content-type"]) + new(attributes_from_node(node)) + end + end + + private + def content_type_is_image?(content_type) + content_type.to_s =~ /^image(\/.+|$)/ + end + + def attributes_from_node(node) + { url: node["url"], + content_type: node["content-type"], + width: node["width"], + height: node["height"] } + end + end + + attr_reader :url, :content_type, :width, :height + + def initialize(attributes = {}) + @url = attributes[:url] + @content_type = attributes[:content_type] + @width = attributes[:width] + @height = attributes[:height] + end + + def attachable_plain_text_representation(caption) + "[#{caption || "Image"}]" + end + + def to_partial_path + "active_text/attachables/remote_image" + end + end + end +end |