Merge pull request #21 from dryabov/master

Cumulative patches
This commit is contained in:
iHedgehog 2014-03-21 16:41:36 +03:00
commit c029f754b2
5 changed files with 25 additions and 16 deletions

View File

@ -4,6 +4,8 @@
background: url("emotions/blank.png") no-repeat center center;
display: inline-block;
vertical-align: top;
color: transparent;
overflow: hidden;
}
.emo-angel {

View File

@ -4,6 +4,8 @@
background: url("emotions/blank.gif") no-repeat center center;
display: inline-block;
vertical-align: top;
color: transparent;
overflow: hidden;
}
.emo-angel {

View File

@ -4,6 +4,8 @@
background: url("emotions/blank.gif") no-repeat center center;
display: inline-block;
vertical-align: bottom;
color: transparent;
overflow: hidden;
}
.emo-angel {

View File

@ -23,7 +23,7 @@
$.extend($.emotions, {
settings: {
replacement: '<span class="emotions emo-{eId}"></span>',
replacement: '<span class="emotions emo-{eId}">$2</span>',
map: {
"o:)": "angel",
"0:)": "angel",
@ -87,15 +87,10 @@
var rep = $s.replacement
.replace(/\{eId\}/g, $s.map[pattern]);
if (pattern[0] === ';') {
text = text
.replace(new RegExp("(^|\\W)" + $t.quote(pattern), "g"), "$1" + rep)
.replace(new RegExp("(^|\\W)" + $t.quote(encPattent), "g"), "$1" + rep);
} else {
text = text
.replace(new RegExp($t.quote(pattern), "g"), rep)
.replace(new RegExp($t.quote(encPattent), "g"), rep);
}
text = text.replace(
new RegExp("(^|\\s)(" + $t.quote(pattern) + "|" + $t.quote(encPattent) + ")(?=\\s|$)", "g"),
"$1" + rep
);
}
return text;

View File

@ -157,7 +157,7 @@ function htmlFormatMsg( msg, output, mentions ) {
if( match ) {
index = (match[0] === match[1]) ? match.index : match.index + 1;
if( match[1] == "@" ) {
output.append($.emotions(msg.substr(0, index)));
output.append(_formatText(msg.substr(0, index)));
tmp = msg.substr(index+1);
var username = _extractUsername(tmp);
if( username.length ) {
@ -177,12 +177,13 @@ function htmlFormatMsg( msg, output, mentions ) {
}
if( reHttp.exec(match[1]) ) {
output.append($.emotions(msg.substr(0, index)));
output.append(_formatText(msg.substr(0, index)));
tmp = msg.substring(index);
var space = tmp.indexOf(" ");
var url;
if( space != -1 ) url = tmp.substring(0,space); else url = tmp;
if( url.length ) {
url = url.replace('&amp;', '&');
var extLinkTemplate = $("#external-page-link-template").clone(true);
extLinkTemplate.removeAttr("id");
extLinkTemplate.attr("href",url);
@ -195,7 +196,7 @@ function htmlFormatMsg( msg, output, mentions ) {
}
if( reEmail.exec(match[1]) ) {
output.append($.emotions(msg.substr(0, index)));
output.append(_formatText(msg.substr(0, index)));
tmp = msg.substring(index);
var space = tmp.indexOf(" ");
var email;
@ -213,7 +214,7 @@ function htmlFormatMsg( msg, output, mentions ) {
}
if( match[1] == "#" ) {
output.append($.emotions(msg.substr(0, index)));
output.append(_formatText(msg.substr(0, index)));
tmp = msg.substr(index+1);
var hashtag = _extractHashtag(tmp);
if( hashtag.length ) {
@ -236,12 +237,19 @@ function htmlFormatMsg( msg, output, mentions ) {
}
}
output.append($.emotions(msg));
output.append(_formatText(msg));
msg = "";
}
}
// internal function for htmlFormatMsg
function _formatText(msg)
{
msg = $.emotions(msg);
msg = msg.replace(/\n/g, '<br />');
return msg;
}
function _extractUsername(s) {
var username = "";
for( var i = 0; i < s.length; i++ ) {
@ -272,5 +280,5 @@ function _extractHashtag(s) {
}
function escapeHtmlEntities(str) {
return str.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/"/g, '&quot;').replace(/'/g, '&apos;');
return str.replace('&', '&amp;').replace('<', '&lt;').replace('>', '&gt;').replace('"', '&quot;').replace("'", '&apos;');
}