mirror of
https://github.com/discourse/discourse.git
synced 2025-01-19 03:22:46 +08:00
FIX: emoji unescape
This commit is contained in:
parent
5865bd2abb
commit
5bd1d52de2
|
@ -30,16 +30,19 @@ for (var name in aliases) {
|
||||||
}
|
}
|
||||||
|
|
||||||
Discourse.Emoji.unescape = function(string) {
|
Discourse.Emoji.unescape = function(string) {
|
||||||
|
//this can be further improved by supporting matches of emoticons that don't begin with a colon
|
||||||
if (Discourse.SiteSettings.enable_emoji && string.indexOf(":") >= 0) {
|
if (Discourse.SiteSettings.enable_emoji && string.indexOf(":") >= 0) {
|
||||||
string = string.replace(/:[^\s:]+:?/g, function(m) {
|
string = string.replace(/\B:[^\s:]+:?\B/g, function(m) {
|
||||||
var emoji = Discourse.Emoji.translations[m] ? Discourse.Emoji.translations[m] : m.slice(1, m.length - 1),
|
var isEmoticon = !!Discourse.Emoji.translations[m],
|
||||||
|
emoji = isEmoticon ? Discourse.Emoji.translations[m] : m.slice(1, m.length - 1),
|
||||||
|
hasEndingColon = m.lastIndexOf(":") === m.length - 1,
|
||||||
url = Discourse.Emoji.urlFor(emoji);
|
url = Discourse.Emoji.urlFor(emoji);
|
||||||
return url ? "<img src='" + url + "' title='" + emoji + "' alt='" + emoji + "' class='emoji'>" : m;
|
return url && (isEmoticon || hasEndingColon) ? "<img src='" + url + "' title='" + emoji + "' alt='" + emoji + "' class='emoji'>" : m;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
return string;
|
return string;
|
||||||
}
|
};
|
||||||
|
|
||||||
Discourse.Emoji.urlFor = urlFor = function(code) {
|
Discourse.Emoji.urlFor = urlFor = function(code) {
|
||||||
var url, set = Discourse.SiteSettings.emoji_set;
|
var url, set = Discourse.SiteSettings.emoji_set;
|
||||||
|
@ -63,12 +66,12 @@ Discourse.Emoji.urlFor = urlFor = function(code) {
|
||||||
}
|
}
|
||||||
|
|
||||||
return url;
|
return url;
|
||||||
}
|
};
|
||||||
|
|
||||||
Discourse.Emoji.exists = function(code){
|
Discourse.Emoji.exists = function(code){
|
||||||
code = code.toLowerCase();
|
code = code.toLowerCase();
|
||||||
return !!(extendedEmoji.hasOwnProperty(code) || emojiHash.hasOwnProperty(code));
|
return !!(extendedEmoji.hasOwnProperty(code) || emojiHash.hasOwnProperty(code));
|
||||||
}
|
};
|
||||||
|
|
||||||
function imageFor(code) {
|
function imageFor(code) {
|
||||||
code = code.toLowerCase();
|
code = code.toLowerCase();
|
||||||
|
@ -204,6 +207,6 @@ Discourse.Emoji.search = function(term, options) {
|
||||||
}
|
}
|
||||||
|
|
||||||
return results;
|
return results;
|
||||||
}
|
};
|
||||||
|
|
||||||
Discourse.Markdown.whiteListTag('img', 'class', 'emoji');
|
Discourse.Markdown.whiteListTag('img', 'class', 'emoji');
|
||||||
|
|
|
@ -91,6 +91,7 @@ Discourse.SiteSettingsOriginal = {
|
||||||
"show_create_topics_notice":true,
|
"show_create_topics_notice":true,
|
||||||
"available_locales":"cs|da|de|en|es|fr|he|id|it|ja|ko|nb_NO|nl|pl_PL|pt|pt_BR|ru|sv|uk|zh_CN|zh_TW",
|
"available_locales":"cs|da|de|en|es|fr|he|id|it|ja|ko|nb_NO|nl|pl_PL|pt|pt_BR|ru|sv|uk|zh_CN|zh_TW",
|
||||||
"highlighted_languages":"apache|bash|cs|cpp|css|coffeescript|diff|xml|http|ini|json|java|javascript|makefile|markdown|nginx|objectivec|ruby|perl|php|python|sql|handlebars",
|
"highlighted_languages":"apache|bash|cs|cpp|css|coffeescript|diff|xml|http|ini|json|java|javascript|makefile|markdown|nginx|objectivec|ruby|perl|php|python|sql|handlebars",
|
||||||
"enable_emoji":true
|
"enable_emoji":true,
|
||||||
|
"emoji_set":"emoji_one"
|
||||||
};
|
};
|
||||||
Discourse.SiteSettings = jQuery.extend(true, {}, Discourse.SiteSettingsOriginal);
|
Discourse.SiteSettings = jQuery.extend(true, {}, Discourse.SiteSettingsOriginal);
|
||||||
|
|
|
@ -52,7 +52,7 @@ test('spoiler', function() {
|
||||||
format("[spoiler]it's a sled[/spoiler]", "<span class=\"spoiler\">it's a sled</span>", "supports spoiler tags on text");
|
format("[spoiler]it's a sled[/spoiler]", "<span class=\"spoiler\">it's a sled</span>", "supports spoiler tags on text");
|
||||||
format("[spoiler]<img src='http://eviltrout.com/eviltrout.png' width='50' height='50'>[/spoiler]",
|
format("[spoiler]<img src='http://eviltrout.com/eviltrout.png' width='50' height='50'>[/spoiler]",
|
||||||
"<span class=\"spoiler\"><img src=\"http://eviltrout.com/eviltrout.png\" width=\"50\" height=\"50\"></span>", "supports spoiler tags on images");
|
"<span class=\"spoiler\"><img src=\"http://eviltrout.com/eviltrout.png\" width=\"50\" height=\"50\"></span>", "supports spoiler tags on images");
|
||||||
format("[spoiler] This is the **bold** :smiley: [/spoiler]", "<span class=\"spoiler\"> This is the <strong>bold</strong> <img src=\"/images/emoji/undefined/smiley.png?v=0\" title=\":smiley:\" class=\"emoji\" alt=\"smiley\"> </span>", "supports spoiler tags on emojis");
|
format("[spoiler] This is the **bold** :smiley: [/spoiler]", "<span class=\"spoiler\"> This is the <strong>bold</strong> <img src=\"/images/emoji/emoji_one/smiley.png?v=0\" title=\":smiley:\" class=\"emoji\" alt=\"smiley\"> </span>", "supports spoiler tags on emojis");
|
||||||
format("[spoiler] Why not both <img src='http://eviltrout.com/eviltrout.png' width='50' height='50'>?[/spoiler]", "<span class=\"spoiler\"> Why not both <img src=\"http://eviltrout.com/eviltrout.png\" width=\"50\" height=\"50\">?</span>", "supports images and text");
|
format("[spoiler] Why not both <img src='http://eviltrout.com/eviltrout.png' width='50' height='50'>?[/spoiler]", "<span class=\"spoiler\"> Why not both <img src=\"http://eviltrout.com/eviltrout.png\" width=\"50\" height=\"50\">?</span>", "supports images and text");
|
||||||
format("In a p tag a spoiler [spoiler] <img src='http://eviltrout.com/eviltrout.png' width='50' height='50'>[/spoiler] can work.", "In a p tag a spoiler <span class=\"spoiler\"> <img src=\"http://eviltrout.com/eviltrout.png\" width=\"50\" height=\"50\"></span> can work.", "supports images and text in a p tag");
|
format("In a p tag a spoiler [spoiler] <img src='http://eviltrout.com/eviltrout.png' width='50' height='50'>[/spoiler] can work.", "In a p tag a spoiler <span class=\"spoiler\"> <img src=\"http://eviltrout.com/eviltrout.png\" width=\"50\" height=\"50\"></span> can work.", "supports images and text in a p tag");
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,10 +1,29 @@
|
||||||
|
|
||||||
module('emoji');
|
module('emoji');
|
||||||
|
|
||||||
|
var testUnescape = function(input, expected, description) {
|
||||||
|
var unescaped = Discourse.Emoji.unescape(input);
|
||||||
|
equal(unescaped, expected, description);
|
||||||
|
};
|
||||||
|
|
||||||
|
test("Emoji.unescape", function(){
|
||||||
|
|
||||||
|
testUnescape("Not emoji :O) :frog) :smile)", "Not emoji :O) :frog) :smile)", "title without emoji");
|
||||||
|
testUnescape("Not emoji :frog :smile", "Not emoji :frog :smile", "end colon is not optional");
|
||||||
|
testUnescape("emoticons :)", "emoticons <img src='/images/emoji/emoji_one/smile.png?v=0' title='smile' alt='smile' class='emoji'>", "emoticons are still supported");
|
||||||
|
testUnescape("With emoji :O: :frog: :smile:",
|
||||||
|
"With emoji <img src='/images/emoji/emoji_one/o.png?v=0' title='O' alt='O' class='emoji'> <img src='/images/emoji/emoji_one/frog.png?v=0' title='frog' alt='frog' class='emoji'> <img src='/images/emoji/emoji_one/smile.png?v=0' title='smile' alt='smile' class='emoji'>",
|
||||||
|
"title with emoji");
|
||||||
|
testUnescape("a:smile:a", "a:smile:a", "word characters not allowed next to emoji");
|
||||||
|
testUnescape("(:frog:) :)", "(<img src='/images/emoji/emoji_one/frog.png?v=0' title='frog' alt='frog' class='emoji'>) <img src='/images/emoji/emoji_one/smile.png?v=0' title='smile' alt='smile' class='emoji'>", "non-word characters allowed next to emoji");
|
||||||
|
testUnescape(":smile: hi", "<img src='/images/emoji/emoji_one/smile.png?v=0' title='smile' alt='smile' class='emoji'> hi", "start of line");
|
||||||
|
testUnescape("hi :smile:", "hi <img src='/images/emoji/emoji_one/smile.png?v=0' title='smile' alt='smile' class='emoji'>", "end of line");
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
test("Emoji.search", function(){
|
test("Emoji.search", function(){
|
||||||
|
|
||||||
// able to find an alias
|
// able to find an alias
|
||||||
equal(Discourse.Emoji.search("coll").length, 1);
|
equal(Discourse.Emoji.search("coll").length, 1);
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -76,6 +76,6 @@ test("recover", function() {
|
||||||
test('fancyTitle', function() {
|
test('fancyTitle', function() {
|
||||||
var topic = Topic.create({ fancy_title: ":smile: with all :) the emojis :pear::peach:" });
|
var topic = Topic.create({ fancy_title: ":smile: with all :) the emojis :pear::peach:" });
|
||||||
equal(topic.get('fancyTitle'),
|
equal(topic.get('fancyTitle'),
|
||||||
"<img src='/images/emoji/undefined/smile.png?v=0' title='smile' alt='smile' class='emoji'> with all <img src='/images/emoji/undefined/smile.png?v=0' title='smile' alt='smile' class='emoji'> the emojis <img src='/images/emoji/undefined/pear.png?v=0' title='pear' alt='pear' class='emoji'><img src='/images/emoji/undefined/peach.png?v=0' title='peach' alt='peach' class='emoji'>",
|
"<img src='/images/emoji/emoji_one/smile.png?v=0' title='smile' alt='smile' class='emoji'> with all <img src='/images/emoji/emoji_one/smile.png?v=0' title='smile' alt='smile' class='emoji'> the emojis <img src='/images/emoji/emoji_one/pear.png?v=0' title='pear' alt='pear' class='emoji'><img src='/images/emoji/emoji_one/peach.png?v=0' title='peach' alt='peach' class='emoji'>",
|
||||||
"supports emojis");
|
"supports emojis");
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue
Block a user