Leetcode Difficulty Kachower

Replace difficulty labels with "Hidden" and apply custom styles.

Fra 23.12.2024. Se den seneste versjonen.

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(I already have a user style manager, let me install it!)

// ==UserScript==
// @name         Leetcode Difficulty Kachower
// @namespace    http://tampermonkey.net/
// @version      1.2
// @description  Replace difficulty labels with "Hidden" and apply custom styles.
// @author       You
// @match        https://leetcode.com/*
// @exclude      https://leetcode.com/
// @exclude      https://leetcode.com
// @grant        none
// @license MIT
// ==/UserScript==

(function () {
    'use strict';

    // Helper function to replace text content and apply styles
    function replaceText(element, customText = "Hidden") {
        if (element.dataset.processed || element.closest("svg")) return; // Skip already processed elements

        // Store the original text
        const originalText = element.textContent.trim();

        // Replace text with "Hidden" and apply styles
        element.textContent = customText;
        element.style.color = "orchid";
        element.dataset.processed = "true";

        // Add hover functionality to show the original text
        element.addEventListener("mouseenter", () => {
            element.textContent = originalText;
            element.style.color = ""; // Reset to original colour
            element.style.fontStyle = "";
            element.style.fontWeight = "";
        });
        element.addEventListener("mouseleave", () => {
            element.textContent = customText;
            element.style.color = "orchid";
        });
    }

    // Apply the text replacement to specific elements
    function applyReplacements() {
        const selectors = [
            ".text-sd-hard",
            ".text-sd-medium",
            ".text-sd-easy",
            '[role="cell"] > .text-pink.dark\\:text-dark-pink',
            '[role="cell"] > .text-yellow.dark\\:text-dark-yellow',
            '[role="cell"] > .text-olive.dark\\:text-dark-olive',
            ".text-difficulty-hard",
            ".text-difficulty-medium",
            ".text-difficulty-easy",
            ".text-lc-yellow-60.dark\\:text-dark-lc-yellow-60",
            ".text-lc-red-60.dark\\:text-dark-lc-red-60",
            ".text-lc-green-60.dark\\:text-dark-lc-green-60",
            ".text-yellow",
            ".text-pink",
            ".text-green",
            ".text-olive"
        ];

        const elements = document.querySelectorAll(selectors.join(","));
        elements.forEach((element) => replaceText(element));
    }

    // Run the replacement initially
    applyReplacements();

    // Observe changes in the DOM to handle dynamic content
    const observer = new MutationObserver((mutations) => {
        mutations.forEach((mutation) => {
            mutation.addedNodes.forEach((node) => {
                if (node.nodeType === Node.ELEMENT_NODE) {
                    applyReplacements();
                }
            });
        });
    });

    observer.observe(document.body, { childList: true, subtree: true });
})();