Greasy Fork - Analyze from posted scripts

Shows the total amount for each rating, total/daily installs, and scripts posted on any user profile and search pages.

Versión del día 17/12/2023. Echa un vistazo a la versión más reciente.

Tendrás que instalar una extensión para tu navegador como Tampermonkey, Greasemonkey o Violentmonkey si quieres utilizar este script.

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

Necesitarás instalar una extensión como Tampermonkey o Violentmonkey para instalar este script.

Necesitarás instalar una extensión como Tampermonkey o Userscripts para instalar este script.

Necesitará instalar una extensión como Tampermonkey para instalar este script.

Necesitarás instalar una extensión para administrar scripts de usuario si quieres instalar este script.

(Ya tengo un administrador de scripts de usuario, déjame instalarlo)

Necesitará instalar una extensión como Stylus para instalar este estilo.

Necesitará instalar una extensión como Stylus para instalar este estilo.

Necesitará instalar una extensión como Stylus para instalar este estilo.

Necesitará instalar una extensión del gestor de estilos de usuario para instalar este estilo.

Necesitará instalar una extensión del gestor de estilos de usuario para instalar este estilo.

Necesitará instalar una extensión del gestor de estilos de usuario para instalar este estilo.

(Ya tengo un administrador de estilos de usuario, déjame instalarlo)

// ==UserScript==
// @name         Greasy Fork - Analyze from posted scripts
// @namespace    ScriptAnalyzer
// @version      6
// @description  Shows the total amount for each rating, total/daily installs, and scripts posted on any user profile and search pages.
// @author       hacker09
// @match        https://greasyfork.org/en/users/*
// @match        https://greasyfork.org/*/scripts?q=*
// @match        https://greasyfork.org/*/scripts/by-site/*
// @icon         https://t2.gstatic.com/faviconV2?client=SOCIAL&type=FAVICON&fallback_opts=TYPE,SIZE,URL&url=https://greasyfork.org/&size=64
// @grant        none
// ==/UserScript==

(async function() {
  'use strict';
  var select, dateresponse, dateDocument, date, ok = 0, bad = 0, Dailytotal = 0, total = 0, good = 0, DocList = [], Scriptposts = 0; //Create new variables

  function Calc(select) { //Create a selector function to calculate values
    select.querySelectorAll(".ok-rating-count").forEach(el => ok += parseInt(el.innerText)); //Add the ratings
    select.querySelectorAll(".bar-rating-count").forEach(el => bad += parseInt(el.innerText)); //Add the ratings
    select.querySelectorAll(".good-rating-count").forEach(el => good += parseInt(el.innerText)); //Add the ratings
    select.querySelectorAll("dd.script-list-total-installs").forEach(el => total += parseInt(el.innerText.replaceAll(',',''))); //Add the total installs
    select.querySelectorAll("dd.script-list-daily-installs").forEach(el => Dailytotal += parseInt(el.innerText.replaceAll(',',''))); //Add the daily installs
  } //Finishes the Calc function

    if (location.href.match('sort=created') === null) { //If the current page is not already being sorted by the created date
      dateresponse = await (await fetch(document.querySelector('a[href$="sort=created"]').href)).text(); //Fetch
      dateDocument = new DOMParser().parseFromString(dateresponse, "text/html"); //Parses the fetch response
      date = dateDocument.querySelector("span > relative-time").textContent; //Save the newest created date
    } //Finishes the if condition
    else //If the current page is already being sorted by the created date
    { //Starts the else condition
      date = document.querySelector("span > relative-time").title; //Save the newest created date
    } //Finishes the else condition

  if (location.href.match('users') !== null && location.href.match('page=') === null) //If the current page is a user profile and isn't a user profile page >= 2
  { //Starts the if condition
    [...document.querySelectorAll(".pagination a:not(.next_page)"), { href: location.href }].forEach(async (el) => { //For each page link including the currently opened one
      await new Promise(r => setTimeout(r, 1000)); //Wait 1 sec before continuing
      const response = await (await fetch(el.href)).text(); //Fetch
      const newDocument = new DOMParser().parseFromString(response, 'text/html'); //Parses the fetch response
      DocList.push(newDocument); //Add the fetched page to an array
    }); //Finishes the forEach loop

    await new Promise(r => setTimeout(r, 2000)); //Wait 2 secs before continuing

    document.head.insertAdjacentHTML('beforeend', '<style>.list-option:not(.list-current) {display: flex; flex-direction: row; align-items: center;} .list-option:not(.list-current) > span {position: relative; left: -7px;} .list-option.list-current > span {position: relative; left: 5px;}</style>'); //Add a space before (

    DocList.forEach(async (docs, i) => { //ForEach page we fetched
      await Calc(docs); //Call the Calc function
      Scriptposts += docs.querySelectorAll("#user-script-list > li").length; //Add the total Script posts

      if (i+1 === DocList.length) { //If it's the last loop
        document.querySelector("#user-script-sets-section,#user-script-list-section").insertAdjacentHTML("afterbegin", `<section><header><h3>Total</h3></header><section class="text-content"><ul><li><b>Script posts</b>: ${Scriptposts}</li><li><b>Daily installs</b>: ${Dailytotal.toLocaleString()}</li><li><b>Total installs</b>: ${total.toLocaleString()}</li><li><b>Total ok ratings</b>: ${ok.toLocaleString()}</li><li><b>Total bad ratings</b>: ${bad.toLocaleString()}</li><li><b>Total good ratings</b>: ${good.toLocaleString()}</li><li><b>Latest created</b>: ${date}</li></ul></section></section>`); //Add the user information on the page
        document.querySelector(".list-option").innerHTML += `<span>(${Dailytotal.toLocaleString()})</span>`; //Add the Dailytotal information on the sidebar
        document.querySelector(".list-option:nth-child(2)").innerHTML += `<span>(${total.toLocaleString()})</span>`; //Add the total information on the sidebar
        document.querySelector(".list-option:nth-child(3)").innerHTML += `<span>(${parseInt(ok+bad+good).toLocaleString()})</span>`; //Add the ratings information on the sidebar
      } //Finishes the if condition
    }); //Finishes the forEach loop
  } //Finishes the if condition

  if (location.href.match(/org\/.*\/scripts/)) //If the current page is a script search page
  { //Starts the else condition
    await Calc(document); //Call the Calc function
    document.querySelector(".width-constraint:nth-child(2)").insertAdjacentHTML("afterbegin", `<section><header><h3>Total</h3></header><section class="text-content"><ul><li><b>Script posts</b>: ${document.querySelectorAll("#browse-script-list > li").length}</li><li><b>Daily installs</b>: ${Dailytotal.toLocaleString()}</li><li><b>Total installs</b>: ${total.toLocaleString()}</li><li><b>Total ok ratings</b>: ${ok.toLocaleString()}</li><li><b>Total bad ratings</b>: ${bad.toLocaleString()}</li><li><b>Total good ratings</b>: ${good.toLocaleString()}</li><li><b>Latest created</b>: ${date}</li></ul></section></section>`); //Add the information on the page
    document.querySelector(".list-option").innerHTML += `<span>(${Dailytotal.toLocaleString()})</span>`; //Add the Dailytotal information on the sidebar
    document.querySelector(".list-option:nth-child(2)").innerHTML += `<span>(${total.toLocaleString()})</span>`; //Add the total information on the sidebar
    document.querySelector(".list-option:nth-child(3)").innerHTML += `<span>(${parseInt(ok+bad+good).toLocaleString()})</span>`; //Add the ratings information on the sidebar
  } //Finishes the else condition
})();