Truncate long richtext descriptions
This commit is contained in:
parent
e5279dacde
commit
88a7ca5625
2 changed files with 20 additions and 4 deletions
|
@ -3,6 +3,8 @@ module RichText
|
||||||
"Business Description:", "Additional Keywords:"
|
"Business Description:", "Additional Keywords:"
|
||||||
].freeze
|
].freeze
|
||||||
|
|
||||||
|
MAX_DESCRIPTION_LENGTH = 500
|
||||||
|
|
||||||
def self.new(format, text)
|
def self.new(format, text)
|
||||||
case format
|
case format
|
||||||
when "html" then HTML.new(text || "")
|
when "html" then HTML.new(text || "")
|
||||||
|
@ -111,7 +113,7 @@ module RichText
|
||||||
|
|
||||||
def description
|
def description
|
||||||
@paragraph_element = first_paragraph_element(document.root) unless defined? @paragraph_element
|
@paragraph_element = first_paragraph_element(document.root) unless defined? @paragraph_element
|
||||||
text_content(@paragraph_element) if @paragraph_element
|
truncated_text_content(@paragraph_element) if @paragraph_element
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
@ -138,19 +140,22 @@ module RichText
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def text_content(element)
|
def truncated_text_content(element)
|
||||||
text = ""
|
text = ""
|
||||||
|
|
||||||
append_text = lambda do |child|
|
append_text = lambda do |child|
|
||||||
if child.type == :text
|
if child.type == :text
|
||||||
text << child.value
|
text << child.value
|
||||||
else
|
else
|
||||||
child.children.each { |c| append_text.call(c) }
|
child.children.each do |c|
|
||||||
|
append_text.call(c)
|
||||||
|
break if text.length > MAX_DESCRIPTION_LENGTH
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
append_text.call(element)
|
append_text.call(element)
|
||||||
|
|
||||||
text
|
text.truncate(MAX_DESCRIPTION_LENGTH)
|
||||||
end
|
end
|
||||||
|
|
||||||
def image?(element)
|
def image?(element)
|
||||||
|
|
|
@ -355,6 +355,17 @@ class RichTextTest < ActiveSupport::TestCase
|
||||||
assert_equal "Can use HTML tags.", r.description
|
assert_equal "Can use HTML tags.", r.description
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_markdown_description_max_length
|
||||||
|
r = RichText.new("markdown", "x" * RichText::MAX_DESCRIPTION_LENGTH)
|
||||||
|
assert_equal "x" * RichText::MAX_DESCRIPTION_LENGTH, r.description
|
||||||
|
|
||||||
|
r = RichText.new("markdown", "y" * (RichText::MAX_DESCRIPTION_LENGTH + 1))
|
||||||
|
assert_equal "#{'y' * (RichText::MAX_DESCRIPTION_LENGTH - 3)}...", r.description
|
||||||
|
|
||||||
|
r = RichText.new("markdown", "*zzzzzzzzz*z" * ((RichText::MAX_DESCRIPTION_LENGTH + 1) / 10.0).ceil)
|
||||||
|
assert_equal "#{'z' * (RichText::MAX_DESCRIPTION_LENGTH - 3)}...", r.description
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def assert_html(richtext, &block)
|
def assert_html(richtext, &block)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue