Greasy Fork

ShowSpinnerCount

Adds spinner count to beatmapset pages

当前为 2022-03-09 提交的版本,查看 最新版本

// ==UserScript==
// @name         ShowSpinnerCount
// @namespace    https://github.com/Magnus-Cosmos
// @version      1.0.0
// @description  Adds spinner count to beatmapset pages
// @author       Magnus Cosmos
// @match        https://osu.ppy.sh/beatmapsets/*
// @require      https://greasyfork.org/scripts/441010-osupageobserver/code/OsuPageObserver.js
// ==/UserScript==

const countSpinnerSvg = `url()`;

function staticPage() {
    [this.type, this.id] = location.pathname.split("/").slice(1).map(val => {
        const int = parseInt(val);
        return val == int ? int : val;
    });
}

function getJson(name) {
    const json = document.querySelector(`#json-${name}`);
    if (json?.textContent != null) {
        return JSON.parse(json.textContent);
    }
    return null;
}

function beatmapHandler(beatmapset) {
    const [currMode, currBeatmap] = location.hash.replace("#", "").split("/").map(val => {
        const int = parseInt(val);
        return val == int ? int : val;
    });
    const beatmap = beatmapset.beatmaps.find((b) => {
        if (b.id === currBeatmap) {
            return b;
        }
    });
    $(".beatmap-basic-stats__entry span").last().text(beatmap.count_spinners);
}

const osuWebObserver = new OsuWebObserver(staticPage, function() {
    switch(this.type) {
        case "beatmapsets": {
            const beatmapset = getJson("beatmapset");
            $(".beatmapset-stats").css("width", "300px");
            $(".beatmapset-info__box--success-rate").css("width", "300px");
            $(".beatmap-basic-stats").append(
                `<div class="beatmap-basic-stats__entry" title="Spinner Count">
                    <div class="beatmap-basic-stats__entry-icon" style="background-image: ${countSpinnerSvg};"></div>
                    <span>-</span>
                </div>`
            );
            beatmapHandler(beatmapset);
            const beatmapObserver = new MutationObserver(() => {
                beatmapHandler(beatmapset);
            });
            const beatmapsetStats = document.querySelector(".beatmapset-stats");
            if (beatmapsetStats) {
                beatmapObserver.observe(beatmapsetStats, {attributes: true, subtree: true});
            }
        }
    }
});