joe
All checks were successful
Deploy App / docker (ubuntu-latest, 2.44.0, 17, 3.8.5) (push) Successful in 1m19s
All checks were successful
Deploy App / docker (ubuntu-latest, 2.44.0, 17, 3.8.5) (push) Successful in 1m19s
This commit is contained in:
parent
b08961adf8
commit
4cd6c27b2b
@ -0,0 +1,71 @@
|
|||||||
|
// ==UserScript==
|
||||||
|
// @name ScoreSaber Utils
|
||||||
|
// @namespace https://ssu.fascinated.cc
|
||||||
|
// @version 1.0.0
|
||||||
|
// @description Useful additions to ScoreSaber!
|
||||||
|
// @author Fascinated
|
||||||
|
// @match https://scoresaber.com/*
|
||||||
|
// @icon https://www.google.com/s2/favicons?sz=64&domain=scoresaber.com
|
||||||
|
// @license MIT
|
||||||
|
// @run-at document-end
|
||||||
|
// @updateURL https://git.fascinated.cc/Fascinated/ScoreSaberUtils-Backend/raw/branch/master/scoresaber-utils.user.js
|
||||||
|
// @downloadURL https://git.fascinated.cc/Fascinated/ScoreSaberUtils-Backend/raw/branch/master/scoresaber-utils.user.js
|
||||||
|
// @grant none
|
||||||
|
// ==/UserScript==
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetches the player from ScoreSaber Utils.
|
||||||
|
*
|
||||||
|
* @param {string} id the player's ID
|
||||||
|
* @returns the player's data
|
||||||
|
*/
|
||||||
|
async function fetchPlayer(id) {
|
||||||
|
const response = await fetch(`https://ssu.fascinated.cc/account/${id}`);
|
||||||
|
return await response.json();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handles the player page logic.
|
||||||
|
*/
|
||||||
|
async function playerPage() {
|
||||||
|
const id = window.location.pathname.split("/")[2];
|
||||||
|
const player = await fetchPlayer(id);
|
||||||
|
|
||||||
|
addStat(
|
||||||
|
"+1 PP",
|
||||||
|
player.rawPerGlobalPerformancePoints.toFixed(2) + "pp",
|
||||||
|
"The amount of pp to increase the global pp by 1pp"
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Inserts a stat into the player's stats.
|
||||||
|
*
|
||||||
|
* @param {string} stat The stat name
|
||||||
|
* @param {string} value The stat value
|
||||||
|
* @param {string} hoverText The hover text
|
||||||
|
*/
|
||||||
|
function addStat(stat, value, hoverText) {
|
||||||
|
const statsElement = document.getElementsByClassName("stats-container")[0];
|
||||||
|
const svelteClass = statsElement.getAttribute("class").split(" ")[1];
|
||||||
|
|
||||||
|
const statElement = document.createElement("div");
|
||||||
|
statElement.className = `stat-item ${svelteClass}`;
|
||||||
|
statElement.innerHTML = `
|
||||||
|
<span class="stat-title ${svelteClass}">${stat}</span>
|
||||||
|
<span class="stat-spacer ${svelteClass}"></span>
|
||||||
|
<span class="stat-content ${svelteClass} has-hover" title="${hoverText}">${value}</span>
|
||||||
|
`;
|
||||||
|
statsElement.appendChild(statElement);
|
||||||
|
}
|
||||||
|
|
||||||
|
(function async() {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
const path = window.location.pathname;
|
||||||
|
const isPlayerPage = path.startsWith("/u/");
|
||||||
|
|
||||||
|
if (isPlayerPage) {
|
||||||
|
playerPage();
|
||||||
|
}
|
||||||
|
})();
|
Loading…
Reference in New Issue
Block a user