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.

Per 18-06-2023. Zie de nieuwste versie.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey, Greasemonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Userscripts.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een gebruikersscriptbeheerder nodig.

(Ik heb al een user script manager, laat me het downloaden!)

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

(Ik heb al een beheerder - laat me doorgaan met de installatie!)

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