// ==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 // @downloadURL https://update.greasyfork.icu/scripts/473703/ShowSpinnerCount%20%28Greasemonkey%20Ver%29.user.js // @updateURL https://update.greasyfork.icu/scripts/473703/ShowSpinnerCount%20%28Greasemonkey%20Ver%29.meta.js // ==/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; } }`);