Commit b5f618bf authored by Guillaume Grossetie's avatar Guillaume Grossetie

Enable image link and lazy loading

parent 69d55850
---
title: Enable image link and lazy loading in AsciiDoc documents
merge_request: 18164
author: Guillaume Grossetie
type: fixed
...@@ -11,6 +11,8 @@ module Banzai ...@@ -11,6 +11,8 @@ module Banzai
Filter::ExternalLinkFilter, Filter::ExternalLinkFilter,
Filter::PlantumlFilter, Filter::PlantumlFilter,
Filter::ColorFilter, Filter::ColorFilter,
Filter::ImageLazyLoadFilter,
Filter::ImageLinkFilter,
Filter::AsciiDocPostProcessingFilter Filter::AsciiDocPostProcessingFilter
] ]
end end
......
...@@ -58,7 +58,7 @@ module Gitlab ...@@ -58,7 +58,7 @@ module Gitlab
}, },
'image with onerror' => { 'image with onerror' => {
input: 'image:https://localhost.com/image.png[Alt text" onerror="alert(7)]', input: 'image:https://localhost.com/image.png[Alt text" onerror="alert(7)]',
output: "<div>\n<p><span><img src=\"https://localhost.com/image.png\" alt='Alt text\" onerror=\"alert(7)'></span></p>\n</div>" output: "<div>\n<p><span><a class=\"no-attachment-icon\" href=\"https://localhost.com/image.png\" target=\"_blank\" rel=\"noopener noreferrer\"><img src=\"\" alt='Alt text\" onerror=\"alert(7)' class=\"lazy\" data-src=\"https://localhost.com/image.png\"></a></span></p>\n</div>"
}, },
'fenced code with inline script' => { 'fenced code with inline script' => {
input: '```mypre"><script>alert(3)</script>', input: '```mypre"><script>alert(3)</script>',
...@@ -73,6 +73,20 @@ module Gitlab ...@@ -73,6 +73,20 @@ module Gitlab
end end
end end
context "images" do
it "does lazy load and link image" do
input = 'image:https://localhost.com/image.png[]'
output = "<div>\n<p><span><a class=\"no-attachment-icon\" href=\"https://localhost.com/image.png\" target=\"_blank\" rel=\"noopener noreferrer\"><img src=\"\" alt=\"image\" class=\"lazy\" data-src=\"https://localhost.com/image.png\"></a></span></p>\n</div>"
expect(render(input, context)).to include(output)
end
it "does not automatically link image if link is explicitly defined" do
input = 'image:https://localhost.com/image.png[link=https://gitlab.com]'
output = "<div>\n<p><span><a href=\"https://gitlab.com\" rel=\"nofollow noreferrer noopener\" target=\"_blank\"><img src=\"\" alt=\"image\" class=\"lazy\" data-src=\"https://localhost.com/image.png\"></a></span></p>\n</div>"
expect(render(input, context)).to include(output)
end
end
context 'with admonition' do context 'with admonition' do
it 'preserves classes' do it 'preserves classes' do
input = <<~ADOC input = <<~ADOC
...@@ -107,7 +121,7 @@ module Gitlab ...@@ -107,7 +121,7 @@ module Gitlab
ADOC ADOC
output = <<~HTML output = <<~HTML
<h2>Title</h2> <h2>Title</h2>
HTML HTML
expect(render(input, context)).to include(output.strip) expect(render(input, context)).to include(output.strip)
...@@ -149,15 +163,15 @@ module Gitlab ...@@ -149,15 +163,15 @@ module Gitlab
ADOC ADOC
output = <<~HTML output = <<~HTML
<div> <div>
<p>This paragraph has a footnote.<sup>[<a id="_footnoteref_1" href="#_footnotedef_1" title="View footnote.">1</a>]</sup></p> <p>This paragraph has a footnote.<sup>[<a id="_footnoteref_1" href="#_footnotedef_1" title="View footnote.">1</a>]</sup></p>
</div> </div>
<div> <div>
<hr> <hr>
<div id="_footnotedef_1"> <div id="_footnotedef_1">
<a href="#_footnoteref_1">1</a>. This is the text of the footnote. <a href="#_footnoteref_1">1</a>. This is the text of the footnote.
</div> </div>
</div> </div>
HTML HTML
expect(render(input, context)).to include(output.strip) expect(render(input, context)).to include(output.strip)
...@@ -183,34 +197,34 @@ module Gitlab ...@@ -183,34 +197,34 @@ module Gitlab
ADOC ADOC
output = <<~HTML output = <<~HTML
<h1>Title</h1> <h1>Title</h1>
<div> <div>
<h2 id="user-content-first-section"> <h2 id="user-content-first-section">
<a class="anchor" href="#user-content-first-section"></a>First section</h2> <a class="anchor" href="#user-content-first-section"></a>First section</h2>
<div> <div>
<div> <div>
<p>This is the first section.</p> <p>This is the first section.</p>
</div> </div>
</div> </div>
</div> </div>
<div> <div>
<h2 id="user-content-second-section"> <h2 id="user-content-second-section">
<a class="anchor" href="#user-content-second-section"></a>Second section</h2> <a class="anchor" href="#user-content-second-section"></a>Second section</h2>
<div> <div>
<div> <div>
<p>This is the second section.</p> <p>This is the second section.</p>
</div> </div>
</div> </div>
</div> </div>
<div> <div>
<h2 id="user-content-thunder"> <h2 id="user-content-thunder">
<a class="anchor" href="#user-content-thunder"></a>Thunder ⚡ !</h2> <a class="anchor" href="#user-content-thunder"></a>Thunder ⚡ !</h2>
<div> <div>
<div> <div>
<p>This is the third section.</p> <p>This is the third section.</p>
</div> </div>
</div> </div>
</div> </div>
HTML HTML
expect(render(input, context)).to include(output.strip) expect(render(input, context)).to include(output.strip)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment