Action Text Attachment
Attachments
serialize attachables to HTML or plain text.
class Person < ApplicationRecord
include ActionText::Attachable
end
attachable = Person.create! name: "Javan"
attachment = ActionText::Attachment.from_attachable(attachable)
attachment.to_html # => "<action-text-attachment sgid=\"BAh7CEk..."
Methods
- caption
- fragment_by_canonicalizing_attachments
- from_attachable
- from_attachables
- from_attributes
- from_node
- full_attributes
- inspect
- new
- to_html
- to_plain_text
- to_s
- with_full_attributes
Constants
ATTRIBUTES | = | %w( sgid content-type url href filename filesize width height previewable presentation caption content ) |
Attributes
[R] | attachable | |
[R] | node |
Class Public methods
fragment_by_canonicalizing_attachments(content)
📝 Source code
# File actiontext/lib/action_text/attachment.rb, line 25
def fragment_by_canonicalizing_attachments(content)
fragment_by_minifying_attachments(fragment_by_converting_trix_attachments(content))
end
🔎 See on GitHub
from_attachable(attachable, attributes = {})
📝 Source code
# File actiontext/lib/action_text/attachment.rb, line 37
def from_attachable(attachable, attributes = {})
if node = node_from_attributes(attachable.to_rich_text_attributes(attributes))
new(node, attachable)
end
end
🔎 See on GitHub
from_attachables(attachables)
📝 Source code
# File actiontext/lib/action_text/attachment.rb, line 33
def from_attachables(attachables)
Array(attachables).filter_map { |attachable| from_attachable(attachable) }
end
🔎 See on GitHub
from_attributes(attributes, attachable = nil)
📝 Source code
# File actiontext/lib/action_text/attachment.rb, line 43
def from_attributes(attributes, attachable = nil)
if node = node_from_attributes(attributes)
from_node(node, attachable)
end
end
🔎 See on GitHub
from_node(node, attachable = nil)
📝 Source code
# File actiontext/lib/action_text/attachment.rb, line 29
def from_node(node, attachable = nil)
new(node, attachable || ActionText::Attachable.from_node(node))
end
🔎 See on GitHub
new(node, attachable)
📝 Source code
# File actiontext/lib/action_text/attachment.rb, line 66
def initialize(node, attachable)
@node = node
@attachable = attachable
end
🔎 See on GitHub
Instance Public methods
caption()
📝 Source code
# File actiontext/lib/action_text/attachment.rb, line 71
def caption
node_attributes["caption"].presence
end
🔎 See on GitHub
full_attributes()
📝 Source code
# File actiontext/lib/action_text/attachment.rb, line 75
def full_attributes
node_attributes.merge(attachable_attributes).merge(sgid_attributes)
end
🔎 See on GitHub
inspect()
📝 Source code
# File actiontext/lib/action_text/attachment.rb, line 129
def inspect
"#<#{self.class.name} attachable=#{attachable.inspect}>"
end
🔎 See on GitHub
to_html()
Converts the attachment to HTML.
attachable = Person.create! name: "Javan"
attachment = ActionText::Attachment.from_attachable(attachable)
attachment.to_html # => "<action-text-attachment sgid=\"BAh7CEk...
📝 Source code
# File actiontext/lib/action_text/attachment.rb, line 121
def to_html
HtmlConversion.node_to_html(node)
end
🔎 See on GitHub
to_plain_text()
Converts the attachment to plain text.
attachable = ActiveStorage::Blob.find_by filename: "racecar.jpg"
attachment = ActionText::Attachment.from_attachable(attachable)
attachment.to_plain_text # => "[racecar.jpg]"
Use the caption
when set:
attachment = ActionText::Attachment.from_attachable(attachable, caption: "Vroom vroom")
attachment.to_plain_text # => "[Vroom vroom]"
The presentation can be overridden by implementing the attachable_plain_text_representation
method:
class Person < ApplicationRecord
include ActionText::Attachable
def attachable_plain_text_representation
"[#{name}]"
end
end
attachable = Person.create! name: "Javan"
attachment = ActionText::Attachment.from_attachable(attachable)
attachment.to_plain_text # => "[Javan]"
📝 Source code
# File actiontext/lib/action_text/attachment.rb, line 108
def to_plain_text
if respond_to?(:attachable_plain_text_representation)
attachable_plain_text_representation(caption)
else
caption.to_s
end
end
🔎 See on GitHub
to_s()
📝 Source code
# File actiontext/lib/action_text/attachment.rb, line 125
def to_s
to_html
end
🔎 See on GitHub
with_full_attributes()
📝 Source code
# File actiontext/lib/action_text/attachment.rb, line 79
def with_full_attributes
self.class.from_attributes(full_attributes, attachable)
end
🔎 See on GitHub