您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
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;
- }
- }`);