123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411
// ==UserScript==
// @name TheColiSmilies
// @namespace https://userscripts-mirror.org/
// @description Over 70 new smileys for The Coli!
// @author numbrz
// @match https://www.thecoli.com/threads/*
// @match https://thecoli.com/threads/*
// @match https://www.thecoli.com/forums/*/post-thread
// @match https://thecoli.com/forums/*/post-thread
// @match https://www.thecoli.com/conversations/*
// @version 1.9
// ==/UserScript==
function getStorageValue(key, defaultValue) {
return localStorage.getItem(key) || defaultValue;
}
function setStorageValue(key, value) {
localStorage.setItem(key, value);
}
var smiliesUrl = getStorageValue("smilies", "|").split("|");
smiliesUrl.pop();
// Original URLs
smiliesUrl.push("http://i.imgur.com/EmjbUBO.png");
smiliesUrl.push("http://i.imgur.com/cIDzJ.png");
smiliesUrl.push("http://i.imgur.com/fiefz6F.jpg");
smiliesUrl.push("http://i.imgur.com/F3nNv0f.png");
smiliesUrl.push("http://i.imgur.com/LoxptTL.png");
smiliesUrl.push("http://i.imgur.com/SfcY06Q.png");
smiliesUrl.push("http://i1233.photobucket.com/albums/ff390/ShaneDawg021/drakeohno1.png");
smiliesUrl.push("http://i.imgur.com/sLFY4kZ.png");
smiliesUrl.push("http://i.imgur.com/kKEpfGI.png");
smiliesUrl.push("http://i.imgur.com/NbLoQMj.gif");
smiliesUrl.push("http://i.imgur.com/EOKiJas.png");
smiliesUrl.push("http://i.imgur.com/DFLXB32.png");
smiliesUrl.push("http://i.imgur.com/d7T9Shk.jpg");
// Additional URLs
smiliesUrl.push("https://i.imgur.com/dX5Epp2.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/hamster.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/usure.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/rejoice.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/dwill.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/smugfavre.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/jawalrus.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/leo.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/pachah1.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/wtb3.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/merchant.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/llLG0.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/trash.png");
smiliesUrl.push("https://i.imgur.com/dX5Epp2.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/ld.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/ooh.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/krs.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/smugdon.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/shaq2.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/babylawd.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/win.png");
smiliesUrl.push("https://www.thecoli.com/media/superman-cape.22015/full");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/mindblown.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/rudy2.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/smugbiden.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/drool.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/biggrin.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/evil.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/ninja_1.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/king.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/no.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/drunk.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/facepalm.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/rambo.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/hug.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/smiley-vault-character-028.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/gag.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/mj.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/boss.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/zzz.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/beatdeadhorse.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/stylin.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/sleepsmilie.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/dj2.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/camby.png");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/coffee.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/sad.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/smile.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/dry.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/tongue.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/bustback.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/weirdo.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/ban.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/stop.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/piss.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/popcorn.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/clap.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/smh.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/smoker.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/blink.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/rolleyes.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/rip.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/tu.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/eek.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/scheme.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/hula.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/devil.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/yawn.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/wub.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/slapfight.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/cook.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/handshake.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/yayo.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/yes.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/huh.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/old.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/hmm.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/mad.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/bow.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/guilty.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/queen.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/cool.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/cheers.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/fire.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/whistle.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/violent.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/thumbsdown.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/confused.gif");
smiliesUrl.push("https://www.thecoli.com/styles/default/xenforo/smilies/angry.gif");
smiliesUrl.push("http://i.imgur.com/kix2b.png");
smiliesUrl.push("http://i.imgur.com/7QFXvPL.jpg");
smiliesUrl.push("http://i.imgur.com/hSv3ubt.png");
smiliesUrl.push("http://i.imgur.com/DBK3DDN.png");
smiliesUrl.push("http://i.imgur.com/VsqFGj1.png");
smiliesUrl.push("http://i.imgur.com/vi02eiN.png");
smiliesUrl.push("http://i.imgur.com/vjSuGkn.png");
smiliesUrl.push("http://i.imgur.com/uY4clRq.png");
smiliesUrl.push("http://i.imgur.com/LxlP95K.png");
smiliesUrl.push("http://i.imgur.com/EnyTCdb.png");
smiliesUrl.push("http://i.imgur.com/pzOPQz4.png");
smiliesUrl.push("http://i.imgur.com/l15FShP.png");
smiliesUrl.push("http://i.imgur.com/BkIcJOM.png");
smiliesUrl.push("http://i.imgur.com/HMQ8zQQ.png");
smiliesUrl.push("http://i.imgur.com/oNkSCgM.png");
smiliesUrl.push("http://i.imgur.com/7bv7Iza.png");
smiliesUrl.push("http://i.imgur.com/86V6ycJ.png");
smiliesUrl.push("http://i.imgur.com/PVok5Df.png");
smiliesUrl.push("http://i.imgur.com/EupBlIY.png");
smiliesUrl.push("http://i.imgur.com/CkHljcm.png");
smiliesUrl.push("http://i.imgur.com/Qf0Vl8v.png");
smiliesUrl.push("http://i.imgur.com/q4DuFoA.png");
smiliesUrl.push("http://i.imgur.com/ouFWb10.png");
smiliesUrl.push("http://i.imgur.com/8qR3JTW.png");
smiliesUrl.push("http://i.imgur.com/7IC5IhG.png");
smiliesUrl.push("http://i.imgur.com/ZPo0ouj.png");
smiliesUrl.push("http://i.imgur.com/b965IiN.png");
smiliesUrl.push("http://i.imgur.com/PnEd1ks.png");
smiliesUrl.push("http://i.imgur.com/UGHu9Tr.png");
smiliesUrl.push("http://i.imgur.com/u62UMg0.png");
smiliesUrl.push("http://i.imgur.com/3853YHY.png");
smiliesUrl.push("http://i.imgur.com/ez6DGzF.png");
smiliesUrl.push("http://i.imgur.com/M2RazVk.png");
smiliesUrl.push("http://i.imgur.com/0syIhzU.png");
smiliesUrl.push("http://i.imgur.com/09Z7ygz.png");
smiliesUrl.push("http://i686.photobucket.com/albums/vv224/SoebyART/aubreywithdachicken.png");
smiliesUrl.push("http://i.imgur.com/8VKXv.png");
smiliesUrl.push("http://i1233.photobucket.com/albums/ff390/ShaneDawg021/stephenahand.png");
smiliesUrl.push("http://i679.photobucket.com/albums/vv153/Khameleon05/beleedat.png");
smiliesUrl.push("http://i679.photobucket.com/albums/vv153/Khameleon05/dontwant.png");
smiliesUrl.push("http://i679.photobucket.com/albums/vv153/Khameleon05/th_hmmm-1.png");
smiliesUrl.push("http://i.imgur.com/04Q0aii.png");
smiliesUrl.push("http://i.imgur.com/sluzJHR.png");
smiliesUrl.push("http://i1233.photobucket.com/albums/ff390/ShaneDawg021/obamalaugh3_zps4f596990.png");
smiliesUrl.push("http://i1233.photobucket.com/albums/ff390/ShaneDawg021/westbrookcmonson_zpse72004bd.png");
smiliesUrl.push("http://i1233.photobucket.com/albums/ff390/ShaneDawg021/bigpokey.png");
smiliesUrl.push("http://i1233.photobucket.com/albums/ff390/ShaneDawg021/paulydareyoukiddingme.png");
smiliesUrl.push("http://i1233.photobucket.com/albums/ff390/ShaneDawg021/willfreshprincescared.png");
smiliesUrl.push("http://i1233.photobucket.com/albums/ff390/ShaneDawg021/raydisgusted.png");
smiliesUrl.push("http://i1233.photobucket.com/albums/ff390/ShaneDawg021/jayzbiglaugh2.png");
smiliesUrl.push("http://i1233.photobucket.com/albums/ff390/ShaneDawg021/smiletongue.png");
smiliesUrl.push("http://i1233.photobucket.com/albums/ff390/ShaneDawg021/wtheellll.png");
let lastCursorPosition;
let smiliesContainer;
function insertIntoEditable(shortname) {
var smilies = smiliesUrl.map((url, index) => ({ url, shortname: `smiley${index}` }));
var smiley = smilies.find(smiley => smiley.shortname === shortname);
if (!smiley) return;
var editableElement = document.querySelector(".fr-element.fr-view[contenteditable='true']");
if (!editableElement) {
console.log("Could not find the editable element.");
return;
}
// Save the current selection
var selection = window.getSelection();
var range = selection.getRangeAt(0);
// Check if the insertion point is within the contenteditable area
if (!editableElement.contains(range.startContainer)) {
console.log("Insertion point is not within the contenteditable area.");
return;
}
// Create the image element
var img = document.createElement("img");
img.src = smiley.url;
img.classList.add("fr-fic", "fr-dii", "fr-draggable");
// Insert the image at the current range
range.deleteContents();
range.insertNode(img);
// Create a text node with a space after the image
var spaceNode = document.createTextNode('\u00A0');
range.setStartAfter(img);
range.insertNode(spaceNode);
// Move the cursor after the inserted space
range.setStartAfter(spaceNode);
range.setEndAfter(spaceNode);
selection.removeAllRanges();
selection.addRange(range);
// Trigger input event to ensure changes are recognized
var inputEvent = new Event('input', {
bubbles: true,
cancelable: true,
});
editableElement.dispatchEvent(inputEvent);
// Update last cursor position
lastCursorPosition = range.cloneRange();
console.log("Inserting smiley:", shortname);
console.log("Editable element found:", editableElement);
console.log("Selection:", selection);
console.log("Range:", range);
}
function observeEditableField() {
var editableElement = document.querySelector(".fr-element.fr-view[contenteditable='true']");
if (editableElement) {
editableElement.addEventListener('mouseup', saveCursorPosition);
editableElement.addEventListener('keyup', saveCursorPosition);
editableElement.addEventListener('keydown', handleKeyNavigation);
}
}
function saveCursorPosition() {
var selection = window.getSelection();
if (selection.rangeCount > 0) {
lastCursorPosition = selection.getRangeAt(0).cloneRange();
}
}
function handleKeyNavigation(event) {
if (event.key === 'ArrowLeft' || event.key === 'ArrowRight') {
var selection = window.getSelection();
var range = selection.getRangeAt(0);
var currentNode = range.startContainer;
var offset = range.startOffset;
function findValidPosition(node, direction) {
while (node) {
if (node.nodeType === Node.ELEMENT_NODE && node.tagName === 'IMG') {
return direction === 'left' ? node : node.nextSibling;
}
if (node.nodeType === Node.TEXT_NODE && node.textContent.trim() !== '') {
return node;
}
node = direction === 'left' ? node.previousSibling : node.nextSibling;
}
return null;
}
var newNode, newOffset;
if (event.key === 'ArrowLeft') {
if (currentNode.nodeType === Node.TEXT_NODE && offset > 0) {
newNode = currentNode;
newOffset = offset - 1;
} else {
newNode = findValidPosition(currentNode.previousSibling || currentNode.parentNode.previousSibling, 'left');
newOffset = newNode && newNode.nodeType === Node.TEXT_NODE ? newNode.textContent.length : 0;
}
} else { // ArrowRight
if (currentNode.nodeType === Node.TEXT_NODE && offset < currentNode.textContent.length) {
newNode = currentNode;
newOffset = offset + 1;
} else {
newNode = findValidPosition(currentNode.nextSibling || currentNode.parentNode.nextSibling, 'right');
newOffset = 0;
}
}
if (newNode) {
range = document.createRange();
range.setStart(newNode, newOffset);
range.collapse(true);
selection.removeAllRanges();
selection.addRange(range);
event.preventDefault();
}
}
}
function insertImgsIntoElement(elem, urls) {
let smilies = urls.map((url, index) => ({ url, shortname: `smiley${index}` }));
for (var i = 0; i < urls.length; i++) {
var img = document.createElement("Img");
img.src = ""; // Placeholder image
img.dataset.src = urls[i]; // Store actual URL in dataset
img.style.cursor = "pointer";
var listener = function(shortname){
return function(event){
event.stopPropagation(); // Stop event from bubbling
insertIntoEditable(shortname);
};
}(smilies[i].shortname);
img.addEventListener('click', listener, false);
elem.appendChild(img);
}
}
function loadSmiliesImages(container) {
var images = container.querySelectorAll('img');
images.forEach(function(img) {
if (img.dataset.src) {
img.src = img.dataset.src;
delete img.dataset.src;
}
});
}
// Find the first editable field or textarea
let editableFields = document.querySelectorAll('[contenteditable="true"], .fr-element.fr-view.fr-element-scroll-visible, textarea.input');
if (editableFields.length > 0) {
// Create a container for smileys
smiliesContainer = document.createElement("div");
smiliesContainer.id = "mySmilies";
smiliesContainer.style.maxWidth = "100%"; // Set max-width to 100%
smiliesContainer.style.minHeight = "150px"; // Set initial height to display three rows
smiliesContainer.style.maxHeight = "75px"; // Set max-height to 75px (will be overridden by resizable)
smiliesContainer.style.overflowY = "auto"; // Make it scrollable
smiliesContainer.style.display = "none"; // Hide by default
// Add CSS rule to prevent text selection within smileys container but allow clicking on images
var style = document.createElement('style');
style.innerHTML = `
#mySmilies {
user-select: none;
max-width: 100%;
min-height: 150px; /* Initial height */
overflow-y: auto;
resize: vertical; /* Make resizable */
overflow: hidden; /* Hide overflow */
}
#mySmilies img {
pointer-events: auto;
max-width: 100%;
height: auto;
}
#mySmilies {
border-bottom: 5px solid #ccc; /* Add border for better visibility */
padding-bottom: 5px; /* Add padding for better visibility */
}
`;
document.head.appendChild(style);
// Create a toggle button
let toggleButton = document.createElement("button");
toggleButton.textContent = "Show/hide Smilies";
toggleButton.addEventListener('click', function(event) {
event.preventDefault(); // Prevent default form submission
smiliesContainer.style.display = smiliesContainer.style.display === "none" ? "block" : "none";
if (smiliesContainer.style.display === "block") {
loadSmiliesImages(smiliesContainer); // Load images when container is shown
}
});
// Insert smiley images into the container with placeholder URLs initially
insertImgsIntoElement(smiliesContainer, smiliesUrl);
// Insert the container and toggle button above or below the first editable field
// Ensure they are not part of the content editable area
let wrapperDiv = document.createElement("div");
wrapperDiv.appendChild(toggleButton);
wrapperDiv.appendChild(smiliesContainer);
if (editableFields[0].contentEditable === "true") {
editableFields[0].parentNode.insertBefore(wrapperDiv, editableFields[0]);
} else {
editableFields[0].parentNode.insertBefore(wrapperDiv, editableFields[0].nextSibling);
}
observeEditableField();
}