|
|
@ -25,6 +25,7 @@ $(document).ready(function() { |
|
|
|
_htmlFormatMsgLinkTemplateHashtag = _htmlFormatMsgLinkTemplateHashtag[0].cloneNode(); |
|
|
|
_htmlFormatMsgLinkTemplateHashtag = _htmlFormatMsgLinkTemplateHashtag[0].cloneNode(); |
|
|
|
_htmlFormatMsgLinkTemplateHashtag.removeAttribute('id'); |
|
|
|
_htmlFormatMsgLinkTemplateHashtag.removeAttribute('id'); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
twister.tmpl.linkShortened = extractTemplate('#template-link-shortened')[0]; |
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
// format "userpost" to html element
|
|
|
|
// format "userpost" to html element
|
|
|
@ -626,13 +627,9 @@ function htmlFormatMsg(msg, opt) { |
|
|
|
+ '</samp><br>' |
|
|
|
+ '</samp><br>' |
|
|
|
); |
|
|
|
); |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
if (getSubStrEnd(msg.str, i + 1, whiteSpacesUrl, false, '') < k) // use only first word as href target, others drop silently
|
|
|
|
if ((x = getSubStrEnd(msg.str, i + 1, whiteSpacesUrl, false, '')) < k) // use only first word as href target, others drop silently
|
|
|
|
k = getSubStrEnd(msg.str, i + 1, whiteSpacesUrl, false, ''); |
|
|
|
k = x; |
|
|
|
if (markoutOpt === 'apply') { |
|
|
|
linkName = applyHtml( // we're handling markup inside [] of []()
|
|
|
|
msg = msgAddHtmlEntity(msg, j - 1, getSubStrEnd(msg.str, k + 1, ')', true, '') + 2, |
|
|
|
|
|
|
|
newHtmlEntityLink(_htmlFormatMsgLinkTemplateExternal, |
|
|
|
|
|
|
|
proxyURL(msg.str.slice(i, k + 1)), |
|
|
|
|
|
|
|
applyHtml( // we're trying markup inside [] of []()
|
|
|
|
|
|
|
|
markout(markout(markout(markout( |
|
|
|
markout(markout(markout(markout( |
|
|
|
{str: linkName, htmlEntities: msg.htmlEntities}, |
|
|
|
{str: linkName, htmlEntities: msg.htmlEntities}, |
|
|
|
markoutOpt, '*', 'b'), // bold
|
|
|
|
markoutOpt, '*', 'b'), // bold
|
|
|
@ -640,22 +637,23 @@ function htmlFormatMsg(msg, opt) { |
|
|
|
markoutOpt, '_', 'u'), // underlined
|
|
|
|
markoutOpt, '_', 'u'), // underlined
|
|
|
|
markoutOpt, '-', 's') // striketrough
|
|
|
|
markoutOpt, '-', 's') // striketrough
|
|
|
|
) |
|
|
|
) |
|
|
|
.replace(/&(?!lt;|gt;)/g, '&') |
|
|
|
.replace(/&(?!lt;|gt;)/g, '&'); |
|
|
|
) |
|
|
|
if (markoutOpt === 'apply') { |
|
|
|
|
|
|
|
if (msg.str.slice(i, i + 6).toLowerCase() === 'twist:' && msg.str[i + 17] === '=' |
|
|
|
|
|
|
|
&& getSubStrStart(msg.str, i + 16, stopCharsRightHashtags, false, '') === i + 6) |
|
|
|
|
|
|
|
msg = msgAddHtmlEntity(msg, j - 1, getSubStrEnd(msg.str, k + 1, ')', true, '') + 2, |
|
|
|
|
|
|
|
newHtmlEntityLink(twister.tmpl.linkShortened, |
|
|
|
|
|
|
|
msg.str.slice(i, i + 18), linkName) |
|
|
|
|
|
|
|
); |
|
|
|
|
|
|
|
else |
|
|
|
|
|
|
|
msg = msgAddHtmlEntity(msg, j - 1, getSubStrEnd(msg.str, k + 1, ')', true, '') + 2, |
|
|
|
|
|
|
|
newHtmlEntityLink(_htmlFormatMsgLinkTemplateExternal, |
|
|
|
|
|
|
|
proxyURL(msg.str.slice(i, k + 1)), linkName) |
|
|
|
); |
|
|
|
); |
|
|
|
} else { // markoutOpt === 'clear' so we're clearing markup
|
|
|
|
} else { // markoutOpt === 'clear' so we're clearing markup
|
|
|
|
str = msg.str.slice(i, k + 1); |
|
|
|
str = msg.str.slice(i, k + 1); |
|
|
|
msg = msgAddHtmlEntity(msg, j - 1, getSubStrEnd(msg.str, k + 1, ')', true, '') + 2, |
|
|
|
msg = msgAddHtmlEntity(msg, j - 1, getSubStrEnd(msg.str, k + 1, ')', true, '') + 2, |
|
|
|
applyHtml( // we're trying to clear markup inside [] of []()
|
|
|
|
linkName); |
|
|
|
markout(markout(markout(markout( |
|
|
|
|
|
|
|
{str: linkName, htmlEntities: msg.htmlEntities}, |
|
|
|
|
|
|
|
markoutOpt, '*', 'b'), // bold
|
|
|
|
|
|
|
|
markoutOpt, '~', 'i'), // italic
|
|
|
|
|
|
|
|
markoutOpt, '_', 'u'), // underlined
|
|
|
|
|
|
|
|
markoutOpt, '-', 's') // striketrough
|
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
.replace(/&(?!lt;|gt;)/g, '&') |
|
|
|
|
|
|
|
); |
|
|
|
|
|
|
|
// here we put link target as plain text to handle it usual way (search http[s]:// and so on)
|
|
|
|
// here we put link target as plain text to handle it usual way (search http[s]:// and so on)
|
|
|
|
i = msg.i + 1 |
|
|
|
i = msg.i + 1 |
|
|
|
msg.str = msg.str.slice(0, i) + ' ' + str + msg.str.slice(i); |
|
|
|
msg.str = msg.str.slice(0, i) + ' ' + str + msg.str.slice(i); |
|
|
@ -692,6 +690,12 @@ function htmlFormatMsg(msg, opt) { |
|
|
|
i = msg.i; |
|
|
|
i = msg.i; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} else if (msg.str.slice(i, i + 6).toLowerCase() === 'twist:' && msg.str[i + 17] === '=' |
|
|
|
|
|
|
|
&& getSubStrStart(msg.str, i + 16, stopCharsRightHashtags, false, '') === i + 6) { |
|
|
|
|
|
|
|
str = msg.str.slice(i, i + 18); |
|
|
|
|
|
|
|
msg = msgAddHtmlEntity(msg, i, i + str.length, |
|
|
|
|
|
|
|
newHtmlEntityLink(twister.tmpl.linkShortened, str, str)); |
|
|
|
|
|
|
|
i = msg.i; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|