Skip to content

Instantly share code, notes, and snippets.

@dustyburwell
Created July 27, 2012 20:01
Show Gist options
  • Save dustyburwell/3190174 to your computer and use it in GitHub Desktop.
Save dustyburwell/3190174 to your computer and use it in GitHub Desktop.
YouTrack comment icons user script
// Copyright (c) 2012, Dusty Burwell
//
// ==UserScript==
// @name Emoticons for YouTrack
// @namespace http://dustyburwell.github.com
// @description Converts text to emoticons in YouTrack.
// @include http://youtrack/*
// @include https://youtrack/*
// ==/UserScript==
var smileSource = '';
var frownSource = '';
var winkSource = '';
var devilSource ='';
var monkeySource = '';
var pigSource = '';
var heartSource = '';
var brokenheartSource = '';
var mustacheSource = '';
var rockoutSource = '';
var shockedSource = '';
var grinSource = '';
var angrySource = '';
var coolSource = '';
var crySource = '';
var straightfaceSource = '';
var slantSource = '';
var tongueSource = '';
var cowbellSource = '';
var crabSource = '';
var winceSource = '';
var kissSource = '';
/* Function to replace text with emoticons
Comments:
- Emoticons that contain other emoticons must go first. E.g., monkey -- :(|) -- also contains frown -- :(
- For some reason, some emoticons that appear as snippets in TL view are partially encapsulated by a span that looks
like this: <span dir=ltr"></span>. The most egregious offenders (monkey, pig), have a temporary fix in place but I
believe the span is inserted around most instances of brackets or partheses. Need to devise regexp to detect and
remove this span if it's breaking up and emoticon. One problem is that (presumably) sometimes the dir=ltr tag is
necessary. How to remove only the tags that mess up the emoticon rendering? Perhaps check for existance of chars that
are contained in emoticons (:, (, ), etc.) and then investigate further to see if it's supposed to be an emoticon?
- When showing a V.v.V (crab) as a snippet in TL view, Gmail strips out the periods. Fix: look for VvV in addition to V.v.V
- Consider using separate replaceText function for TL view to deal with snippets.
- This function replaces matches with the given string, and then returns the edited string. Would it be more efficient to test the string first using RegExp.test(string)?
- Consider rewriting function using "for...in" syntax. (I tried this approach initially and could not get it to work.)
- Require white space to render emoticons? I tried both ways and got false positives in both directions. Prob. better to require white
spaces, or at least a white space on either side. One problem is that if the emoticon is at the end of a row line, there's usually a <br>
tag right next to it which means there's no trailing white space. I'm leery about using a more complex regexp b/c it could slow things down
but I will check with the experts in the regexp forum.
- Need to create special button to turn emoticon rendering on or off in case of false positives
*/
function replaceText(textBlock) {
textBlock = textBlock.replace(/:\<span dir="ltr"\>\(\|\)\<\/span\>/g, "<img class='emoticon' src='" + monkeySource + "' />"); // monkey snippet view- :(|)
textBlock = textBlock.replace(/:\(\|\)/g, "<img class='emoticon' src='" + monkeySource + "' />"); // monkey- :(|)
textBlock = textBlock.replace(/:<span dir="ltr"\>\(:\)\<\/span\>/g, "<img class='emoticon' src='" + pigSource + "' />"); // pig snippet view- :(:)
textBlock = textBlock.replace(/:\(:\)/g, "<img class='emoticon' src='" + pigSource + "' />"); // pig- :(:)
textBlock = textBlock.replace(/\}:-\)/g, "<img class='emoticon' src='" + devilSource + "' />"); // devil- }:-)
textBlock = textBlock.replace(/:\)/g, "<img class='emoticon' src='" + smileSource + "' />"); // smile- :)
textBlock = textBlock.replace(/:-\)/g, "<img class='emoticon' src='" + smileSource + "' />"); // smile- :-)
textBlock = textBlock.replace(/;\)/g, "<img class='emoticon' src='" + winkSource + "' />"); // wink- ;)
textBlock = textBlock.replace(/;-\)/g, "<img class='emoticon' src='" + winkSource + "' />"); // wink- ;-)
textBlock = textBlock.replace(/:\(/g, "<img class='emoticon' src='" + frownSource + "' />"); // frown- :(
textBlock = textBlock.replace(/:-\(/g, "<img class='emoticon' src='" + frownSource + "' />"); // frown- :-(
textBlock = textBlock.replace(/\&lt;3/g, "<img class='emoticon' src='" + heartSource + "' />"); // heart-&lt;3
textBlock = textBlock.replace(/&lt;\/3/g, "<img class='emoticon' src='" + brokenheartSource + "' />"); // brokenheart-&lt;/3
textBlock = textBlock.replace(/&lt;\\3/g, "<img class='emoticon' src='" + brokenheartSource + "' />"); // brokenheart-&lt;\3
textBlock = textBlock.replace(/:\{/g, "<img class='emoticon' src='" + mustacheSource + "' />"); // mustache- :{
textBlock = textBlock.replace(/\\m\//g, "<img class='emoticon' src='" + rockoutSource + "' />"); // rockout- \m/
textBlock = textBlock.replace(/:-o/gi, "<img class='emoticon' src='" + shockedSource + "' />"); // shocked- :-o
textBlock = textBlock.replace(/:D/g, "<img class='emoticon' src='" + grinSource + "' />"); // grin- :D
textBlock = textBlock.replace(/=D/g, "<img class='emoticon' src='" + grinSource + "' />"); // grin- =D
textBlock = textBlock.replace(/=\)/g, "<img class='emoticon' src='" + grinSource + "' />"); // grin- =)
textBlock = textBlock.replace(/:-D/g, "<img class='emoticon' src='" + grinSource + "' />"); // grin- :-D
textBlock = textBlock.replace(/x-\(/gi, "<img class='emoticon' src='" + angrySource + "' />"); // angry- x-(
textBlock = textBlock.replace(/B-\)/g, "<img class='emoticon' src='" + coolSource + "' />"); // cool- B-)
textBlock = textBlock.replace(/:'\(/g, "<img class='emoticon' src='" + crySource + "' />"); // cry- :'(
textBlock = textBlock.replace(/:\|/g, "<img class='emoticon' src='" + straightfaceSource + "' />"); // straightface- :|
textBlock = textBlock.replace(/:-\|/g, "<img class='emoticon' src='" + straightfaceSource + "' />"); // straightface- :-|
textBlock = textBlock.replace(/:-\//g, "<img class='emoticon' src='" + slantSource + "' />"); // slant- :-/
textBlock = textBlock.replace(/=\//g, "<img class='emoticon' src='" + slantSource + "' />"); // slant- =/
textBlock = textBlock.replace(/:P/gi, "<img class='emoticon' src='" + tongueSource + "' />"); // tongue- :P or :p
textBlock = textBlock.replace(/=P/g, "<img class='emoticon' src='" + tongueSource + "' />"); // tongue- =P
textBlock = textBlock.replace(/:-P/gi, "<img class='emoticon' src='" + tongueSource + "' />"); // tongue- :-P or :-p
textBlock = textBlock.replace(/\+\/'\\/g, "<img class='emoticon' src='" + cowbellSource + "' />"); // cowbell- +/'\
textBlock = textBlock.replace(/V\.?v\.?V/g, "<img class='emoticon' src='" + crabSource + "' />"); // crab- V.v.V or VvV (tl snippets remove periods)
textBlock = textBlock.replace(/\&gt;\.\&lt;/g, "<img class='emoticon' src='" + winceSource + "' />"); // wince- >.<
textBlock = textBlock.replace(/:-x/gi, "<img class='emoticon' src='" + kissSource + "' />"); // kiss- :-x
textBlock = textBlock.replace(/:\*/g, "<img class='emoticon' src='" + kissSource + "' />"); // kiss- :*
return textBlock;
}
function addEmoticons() {
var contentDivs = window.top.document.getElementsByClassName("wiki");
if (contentDivs.length > 0) {
for (var j = 0; j < contentDivs.length; j++) {
var contentDiv = contentDivs[j].innerHTML;
contentDiv = replaceText(contentDiv);
contentDivs[j].innerHTML = contentDiv;
}
}
}
/* First, add emoticons when the script first loads */
addEmoticons();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment