FIX: Emoji sizes in emails should be done by the EmailStyler

This commit is contained in:
Robin Ward 2013-06-13 12:15:05 -04:00
parent 3f03ce3c8c
commit 66f5a3f6f6
5 changed files with 108 additions and 48 deletions

View File

@ -725,6 +725,8 @@ en:
Your friends at [Discourse](http://www.discourse.org) Your friends at [Discourse](http://www.discourse.org)
:smile:
[0]: %{base_url} [0]: %{base_url}
[1]: http://www.kitterman.com/spf/validate.html [1]: http://www.kitterman.com/spf/validate.html
[2]: http://mxtoolbox.com/SuperTool.aspx [2]: http://mxtoolbox.com/SuperTool.aspx

View File

@ -21,16 +21,19 @@ module Email
end end
def html def html
cooked = PrettyText.cook(text) style = Email::Styles.new(PrettyText.cook(text))
style.format_basic
if @opts[:html_template] if @opts[:html_template]
style.format_html
ActionView::Base.new(Rails.configuration.paths["app/views"]).render( ActionView::Base.new(Rails.configuration.paths["app/views"]).render(
template: 'email/template', template: 'email/template',
format: :html, format: :html,
locals: { html_body: Email::Styles.new(cooked).format, logo_url: logo_url } locals: { html_body: style.to_html, logo_url: logo_url }
) )
else else
cooked style.to_html
end end
end end

View File

@ -7,44 +7,58 @@ module Email
def initialize(html) def initialize(html)
@html = html @html = html
@fragment = Nokogiri::HTML.fragment(@html)
end end
def format def format_basic
fragment = Nokogiri::HTML.fragment(@html) @fragment.css('img').each do |img|
fragment.css('h3').each do |h3| if img['src'] =~ /\/assets\/emoji\//
h3['style'] = 'margin: 15px 0 20px 0; border-bottom: 1px solid #ddd;' img['style'] = "width: 20px; height: 20px;"
end else
fragment.css('hr').each do |hr|
hr['style'] = 'background-color: #ddd; height: 1px; border: 1px;'
end
fragment.css('img').each do |img|
img['style'] = "max-width: 694px;" img['style'] = "max-width: 694px;"
end end
fragment.css('a').each do |a| if img['src'][0] == "/"
img['src'] = "#{Discourse.base_url}#{img['src']}"
end
end
end
def format_html
@fragment.css('h3').each do |h3|
h3['style'] = 'margin: 15px 0 20px 0; border-bottom: 1px solid #ddd;'
end
@fragment.css('hr').each do |hr|
hr['style'] = 'background-color: #ddd; height: 1px; border: 1px;'
end
@fragment.css('a').each do |a|
a['style'] = 'text-decoration: none; font-weight: bold; font-size: 15px; color: #006699;' a['style'] = 'text-decoration: none; font-weight: bold; font-size: 15px; color: #006699;'
end end
fragment.css('ul').each do |ul| @fragment.css('ul').each do |ul|
ul['style'] = 'margin: 0 0 0 10px; padding: 0 0 0 20px;' ul['style'] = 'margin: 0 0 0 10px; padding: 0 0 0 20px;'
end end
fragment.css('li').each do |li| @fragment.css('li').each do |li|
li['style'] = 'padding-bottom: 10px' li['style'] = 'padding-bottom: 10px'
end end
fragment.css('pre').each do |pre| @fragment.css('pre').each do |pre|
pre.replace(pre.text) pre.replace(pre.text)
end end
fragment.css('div.digest-post').each do |div| @fragment.css('div.digest-post').each do |div|
div['style'] = 'margin-left: 15px; margin-top: 20px; max-width: 694px;' div['style'] = 'margin-left: 15px; margin-top: 20px; max-width: 694px;'
end end
end
fragment.to_html def to_html
@fragment.to_html
end end

View File

@ -3,38 +3,85 @@ require 'email'
describe Email::Styles do describe Email::Styles do
def style_exists(html, css_rule) def basic_fragment(html)
fragment = Nokogiri::HTML.fragment(Email::Styles.new(html).format) styler = Email::Styles.new(html)
element = fragment.at(css_rule) styler.format_basic
expect(element["style"]).not_to be_blank Nokogiri::HTML.fragment(styler.to_html)
end end
it "returns blank from an empty string" do def html_fragment(html)
Email::Styles.new("").format.should be_blank styler = Email::Styles.new(html)
styler.format_basic
styler.format_html
Nokogiri::HTML.fragment(styler.to_html)
end
context "basic formatter" do
it "works with an empty string" do
style = Email::Styles.new("")
style.format_basic
expect(style.to_html).to be_blank
end
it "adds a max-width to images" do
frag = basic_fragment("<img src='gigantic.jpg'>")
expect(frag.at("img")["style"]).to match("max-width")
end
it "adds a width and height to images with an emoji path" do
frag = basic_fragment("<img src='/assets/emoji/fish.png'>")
expect(frag.at("img")["style"]).to match("width:")
expect(frag.at("img")["style"]).to match("height:")
end
it "converts relative paths to absolute paths" do
frag = basic_fragment("<img src='/some-image.png'>")
expect(frag.at("img")["src"]).to eq("#{Discourse.base_url}/some-image.png")
end
end
context "html template formatter" do
it "works with an empty string" do
style = Email::Styles.new("")
style.format_html
expect(style.to_html).to be_blank
end end
it "attaches a style to h3 tags" do it "attaches a style to h3 tags" do
style_exists("<h3>hello</h3>", "h3") frag = html_fragment("<h3>hello</h3>")
expect(frag.at('h3')['style']).to be_present
end end
it "attaches a style to hr tags" do it "attaches a style to hr tags" do
style_exists("hello<hr>", "hr") frag = html_fragment("hello<hr>")
expect(frag.at('hr')['style']).to be_present
end end
it "attaches a style to a tags" do it "attaches a style to a tags" do
style_exists("<a href='#'>wat</a>", "a") frag = html_fragment("<a href='#'>wat</a>")
expect(frag.at('a')['style']).to be_present
end end
it "attaches a style to ul tags" do it "attaches a style to a tags" do
style_exists("<ul><li>hello</li></ul>", "ul") frag = html_fragment("<a href='#'>wat</a>")
expect(frag.at('a')['style']).to be_present
end end
it "attaches a style to li tags" do it "attaches a style to ul and li tags" do
style_exists("<ul><li>hello</li></ul>", "li") frag = html_fragment("<ul><li>hello</li></ul>")
expect(frag.at('ul')['style']).to be_present
expect(frag.at('li')['style']).to be_present
end end
it "removes pre tags but keeps their contents" do it "removes pre tags but keeps their contents" do
expect(Email::Styles.new("<pre>hello</pre>").format).to eq("hello") style = Email::Styles.new("<pre>hello</pre>")
style.format_basic
style.format_html
expect(style.to_html).to eq("hello")
end
end end
end end

View File

@ -7,16 +7,10 @@
var text = event.detail; var text = event.detail;
var opts = event.opts; var opts = event.opts;
style = ""
if (opts && opts.environment === "email") {
// Hard code sizes for email view
style = 'width="20" height="20"';
}
this.textResult = text.replace(/\:([a-z\_\+\-0-9]+)\:/g, function (m1, m2) { this.textResult = text.replace(/\:([a-z\_\+\-0-9]+)\:/g, function (m1, m2) {
var url = Discourse.getURL('/assets/emoji/' + m2 + '.png'); var url = Discourse.getURL('/assets/emoji/' + m2 + '.png');
return (emoji.indexOf(m2) !== -1) ? return (emoji.indexOf(m2) !== -1) ?
'<img alt="' + m2 + '" title=":' + m2 + ':" src="' + url + '" ' + style + ' class="emoji"/>' : '<img alt="' + m2 + '" title=":' + m2 + ':" src="' + url + '" class="emoji"/>' :
m1; m1;
}); });
}); });