FIX: strip spoilers in notification excerpts

This commit is contained in:
Penar Musaraj 2019-04-12 12:00:49 -04:00
parent 76e76140e1
commit 55942224ed
4 changed files with 21 additions and 3 deletions

View File

@ -429,7 +429,7 @@ class PostAlerter
post_number: post.post_number,
topic_title: post.topic.title,
topic_id: post.topic.id,
excerpt: excerpt || post.excerpt(400, text_entities: true, strip_links: true, remap_emoji: true),
excerpt: excerpt || post.excerpt(400, text_entities: true, strip_links: true, remap_emoji: true, strip_spoilers: true),
username: username || post.username,
post_url: post_url
}

View File

@ -347,6 +347,7 @@ en:
revert_version_same: "The current version is same as the version you are trying to revert to."
excerpt_image: "image"
excerpt_spoiler: "spoiler"
groups:
success:

View File

@ -17,6 +17,7 @@ class ExcerptParser < Nokogiri::XML::SAX::Document
@keep_emoji_images = options[:keep_emoji_images] == true
@keep_onebox_source = options[:keep_onebox_source] == true
@remap_emoji = options[:remap_emoji] == true
@strip_spoilers = options[:strip_spoilers] == true
@start_excerpt = false
@in_details_depth = 0
@summary_contents = ""
@ -110,7 +111,11 @@ class ExcerptParser < Nokogiri::XML::SAX::Document
end
# Preserve spoilers
if attributes.include?(["class", "spoiler"])
if @strip_spoilers
characters("[#{I18n.t 'excerpt_spoiler'}]")
else
include_tag("span", attributes)
end
@in_spoiler = true
end
@ -194,6 +199,8 @@ class ExcerptParser < Nokogiri::XML::SAX::Document
@excerpt << before_string if before_string
string = "" if @in_spoiler && @strip_spoilers
encode = encode ? lambda { |s| ERB::Util.html_escape(s) } : lambda { |s| s }
if count_it && @current_length + string.length > @length
length = [0, @length - @current_length - 1].max

View File

@ -32,4 +32,14 @@ describe ExcerptParser do
expect(ExcerptParser.get_excerpt(html, 3, {})).to match_html('<details class="disabled"><summary>foo</summary></details>')
expect(ExcerptParser.get_excerpt(html, 2, {})).to match_html('<details class="disabled"><summary>fo&hellip;</summary></details>')
end
it "preserves spoilers by default" do
html = 'Foo <span class="spoiler">bar</span>'
expect(ExcerptParser.get_excerpt(html, 100, {})).to match_html('Foo <span class="spoiler">bar</span>')
end
it "strips spoilers when specified" do
html = 'Foo <span class="spoiler">bar</span>'
expect(ExcerptParser.get_excerpt(html, 100, strip_spoilers: true)).to match_html("Foo [#{I18n.t 'excerpt_spoiler'}]")
end
end