Sankaku Restore Tag Count

Reads the number of posts on a tag from the tooltip and adds the number back after the tag in the tag list.

Verzia zo dňa 18.06.2023. Pozri najnovšiu verziu.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey, Greasemonkey alebo Violentmonkey.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey, % alebo Violentmonkey.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey, % alebo Violentmonkey.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey alebo Userscripts.

Na inštaláciu tohto skriptu je potrebné nainštalovať rozšírenie, ako napríklad Tampermonkey.

Na inštaláciu tohto skriptu je potrebné nainštalovať rozšírenie správcu používateľských skriptov.

(Už mám správcu používateľských skriptov, nechajte ma ho nainštalovať!)

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie, ako napríklad Stylus.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie, ako napríklad Stylus.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie, ako napríklad Stylus.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie správcu používateľských štýlov.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie správcu používateľských štýlov.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie správcu používateľských štýlov.

(Už mám správcu používateľských štýlov, nechajte ma ho nainštalovať!)

// ==UserScript==
// @name         Sankaku Restore Tag Count
// @version      1.0
// @description  Reads the number of posts on a tag from the tooltip and adds the number back after the tag in the tag list.
// @include      https://chan.sankakucomplex.com/post/*
// @grant        none
// @license MIT
// @namespace https://greasyfork.org/users/1104432
// ==/UserScript==


// Function to move the tag's posts count after the tag name for each element
function moveTagPostsCountForAll() {
    var tagContainers = document.querySelectorAll('div[id^="tag_container"]'); // Find all tag container elements

    // Iterate through each tag container element
    tagContainers.forEach(function(tagContainer) {
        var tagLink = tagContainer.querySelector('a[id^="tag"]'); // Find the tag link element inside the container
        var postsCount = getCount(tagContainer.querySelector('span[role="tooltip"] span:nth-of-type(1)').innerHTML); // Find the posts count element inside the tooltip

        // Check if both the tag link and posts count elements exist
        if (tagLink && postsCount) {
            // Move the posts count element after the tag link
            tagLink.parentNode.insertBefore(postsCount, tagLink.nextSibling);
        }
    });
}

function getCount(details) {
  var re = new RegExp("Posts: (.+?)(<br>)", "g");
  var transformedNumber = transformNumber(re.exec(details)[1]);

  // Create a span element to wrap the transformed number and apply the gray color
  var span = document.createElement('span');
  span.style.color = 'gray';
  span.appendChild(document.createTextNode(' ' + transformedNumber));

  return span;
}

function transformNumber(numberString) {
    const numberParts = numberString.trim().split(/(\d+\.?\d*)([KMB])?/);
    let number = parseFloat(numberParts[1]);
    const suffix = numberParts[2];

    if (suffix === 'K') {
        number *= 1000;
    } else if (suffix === 'M') {
        number *= 1000000;
    }

    return number.toLocaleString("ro-RO", {
        useGrouping: true
    });
}

// Call the function to move the tag's posts count after the tag name for all elements
moveTagPostsCountForAll();