Surprise! We've been running on hardware provided by BuyVM for a few months and wanted to show them a little appreciation.
Running a paste site comes with unique challenges, ones that aren't always obvious and hard to control. As such, BuyVM offered us a home where we could worry less about the hosting side of things and focus on maintaining a clean and useful service! Go check them out and show them some love!
Submitted on September 13, 2024 at 09:30 PM

New Paste 1 (Text)

// ==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();
}