ShowSpinnerCount (Greasemonkey Ver)

Adds spinner count to beatmap pages

  1. // ==UserScript==
  2. // @name ShowSpinnerCount (Greasemonkey Ver)
  3. // @namespace osu
  4. // @version 1.0.1
  5. // @description Adds spinner count to beatmap pages
  6. // @author Magnus Cosmos
  7. // @match https://osu.ppy.sh/*
  8. // @match https://lazer.ppy.sh/*
  9. // @run-at document-start
  10. // ==/UserScript==
  11.  
  12. const countSpinnerSvg = `"url()"`;
  13.  
  14. window.eval(`
  15. function getReact() {
  16. return new Promise((resolve) => {
  17. const defineProperty = Object.defineProperty;
  18. Object.defineProperty = function () {
  19. defineProperty.apply(this, arguments);
  20. const prop = arguments[1];
  21. const descriptor = arguments[2];
  22. if (descriptor.get && descriptor.get.a) {
  23. if ("createElement" in descriptor.get.a) {
  24. Object.defineProperty = defineProperty;
  25. resolve(descriptor.get.a);
  26. }
  27. }
  28. }
  29. });
  30. }
  31.  
  32. getReact().then((react) => {
  33. const createElement = react.createElement;
  34. react.createElement = function() {
  35. const r = createElement.apply(this, arguments);
  36. if (arguments[1]?.className === "beatmap-basic-stats") {
  37. const countSpinners = r._owner.stateNode.renderEntry("count_spinners");
  38. countSpinners.props.children[0].props.style.backgroundImage = ${countSpinnerSvg};
  39. countSpinners.props.title = "Spinner Count";
  40. r.props.children.push(countSpinners);
  41. }
  42. return r;
  43. }
  44. });`);
  45.  
  46. function addStyle(css) {
  47. const head = document.querySelector("head");
  48. if (head) {
  49. const style = document.createElement("style");
  50. style.type = "text/css";
  51. style.innerHTML = css.replace(/;/g, " !important;");
  52. head.appendChild(style);
  53. }
  54. }
  55.  
  56. addStyle(`
  57. @media (min-width: 900px) {
  58. .beatmapset-header {
  59. grid-template-columns: 1fr 320px;
  60. }
  61. .beatmapset-info {
  62. grid-template-columns: 1fr 175px 320px;
  63. }
  64. }`);