]> git.openstreetmap.org Git - rails.git/commitdiff
Skip paragraphs with no text when looking for richtext description
authorAnton Khorev <tony29@yandex.ru>
Wed, 7 Aug 2024 04:46:10 +0000 (07:46 +0300)
committerAnton Khorev <tony29@yandex.ru>
Wed, 7 Aug 2024 05:02:19 +0000 (08:02 +0300)
lib/rich_text.rb
test/lib/rich_text_test.rb

index 03800725ad98cc8af64c561288c4e0ff6269f39a..bdf9c37ca7359eec1f2cea57c2243178d8ce7791 100644 (file)
@@ -112,8 +112,9 @@ module RichText
     end
 
     def description
-      @paragraph_element = first_paragraph_element(document.root) unless defined? @paragraph_element
-      truncated_text_content(@paragraph_element) if @paragraph_element
+      return @description if defined? @description
+
+      @description = first_truncated_text_content(document.root)
     end
 
     private
@@ -131,12 +132,14 @@ module RichText
       end
     end
 
-    def first_paragraph_element(element)
-      return element if paragraph?(element)
-
-      element.children.find do |child|
-        nested_paragraph = first_paragraph_element(child)
-        break nested_paragraph if nested_paragraph
+    def first_truncated_text_content(element)
+      if paragraph?(element)
+        truncated_text_content(element)
+      else
+        element.children.find do |child|
+          text = first_truncated_text_content(child)
+          break text unless text.nil?
+        end
       end
     end
 
@@ -155,6 +158,8 @@ module RichText
       end
       append_text.call(element)
 
+      return nil if text.blank?
+
       text.truncate(MAX_DESCRIPTION_LENGTH)
     end
 
index e2cb5ea2655dabdcfd2ca3d0a8b09039257a0a68..63c70b0996f59520e9cde2d4702c5f1a3b16f064 100644 (file)
@@ -345,6 +345,16 @@ class RichTextTest < ActiveSupport::TestCase
     assert_equal "Here starts the text.", r.description
   end
 
+  def test_markdown_description_after_image
+    r = RichText.new("markdown", "![bar](https://example.com/image.jpg)\n\nThis is below the image.")
+    assert_equal "This is below the image.", r.description
+  end
+
+  def test_markdown_description_only_first_paragraph
+    r = RichText.new("markdown", "This thing.\n\nMaybe also that thing.")
+    assert_equal "This thing.", r.description
+  end
+
   def test_markdown_description_elements
     r = RichText.new("markdown", "*Something* **important** [here](https://example.com/).")
     assert_equal "Something important here.", r.description