Truncate long richtext descriptions

This commit is contained in:
Anton Khorev 2024-08-07 06:53:43 +03:00
parent e5279dacde
commit 88a7ca5625
2 changed files with 20 additions and 4 deletions

View file

@ -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)

View file

@ -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)