ShowSpinnerCount (Greasemonkey Ver)

Adds spinner count to beatmap pages

// ==UserScript==
// @name         ShowSpinnerCount (Greasemonkey Ver)
// @namespace    osu
// @version      1.0.1
// @description  Adds spinner count to beatmap pages
// @author       Magnus Cosmos
// @match        https://osu.ppy.sh/*
// @match        https://lazer.ppy.sh/*
// @run-at       document-start
// ==/UserScript==

const countSpinnerSvg = `"url()"`;

window.eval(`
function getReact() {
    return new Promise((resolve) => {
        const defineProperty = Object.defineProperty;
        Object.defineProperty = function () {
            defineProperty.apply(this, arguments);
            const prop = arguments[1];
            const descriptor = arguments[2];
            if (descriptor.get && descriptor.get.a) {
                if ("createElement" in descriptor.get.a) {
                    Object.defineProperty = defineProperty;
                    resolve(descriptor.get.a);
                }
            }
        }
    });
}

getReact().then((react) => {
    const createElement = react.createElement;
    react.createElement = function() {
        const r = createElement.apply(this, arguments);
        if (arguments[1]?.className === "beatmap-basic-stats") {
            const countSpinners = r._owner.stateNode.renderEntry("count_spinners");
            countSpinners.props.children[0].props.style.backgroundImage = ${countSpinnerSvg};
            countSpinners.props.title = "Spinner Count";
            r.props.children.push(countSpinners);
        }
        return r;
    }
});`);

function addStyle(css) {
    const head = document.querySelector("head");
    if (head) {
        const style = document.createElement("style");
        style.type = "text/css";
        style.innerHTML = css.replace(/;/g, " !important;");
        head.appendChild(style);
    }
}

addStyle(`
@media (min-width: 900px) {
    .beatmapset-header {
        grid-template-columns: 1fr 320px;
    }
    .beatmapset-info {
        grid-template-columns: 1fr 175px 320px;
    }
}`);