您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
3/17/2025, 4:31:41 PM
// ==UserScript== // @name weighted grade formatter // @version 4 // @run-at document-start // @author rssaromeo // @match *://learn.vccs.edu/courses/*/grades* // @match *://*/courses/*/grades* // @grant none // @license GPLv3 // @icon  // @description 3/17/2025, 4:31:41 PM // @namespace https://greasyforks.org/users/1184528 // ==/UserScript== ;(async () => { const a = loadlib("allfuncs") await a.waitforelem([ // "#assignments-not-weighted > div:nth-child(1) > table>tbody", "#grades_summary > tbody>tr:has(th > div)", "td.assignment_score > div > span.tooltip", ".original_points", ".original_score", ]) await a.wait(1000) updateGrades() //setInterval(updateGrades, 5000) async function updateGrades() { var table = a.qs( "#assignments-not-weighted > div:nth-child(1) > table>tbody" ) var elems = {} var grades = a .qsa("#grades_summary > tbody>tr:has(th > div)") .forEach((e) => { var tc = a.qs("th > div", e).textContent elems[tc] ??= [] elems[tc].push( a.qs("td.assignment_score > div > span.tooltip", e) ) }) log(elems) for (var tr of table?a.qsa("tr", table):Object.values(elems).flat()) { var val = table?Number(a.qs("td", tr).textContent.replace("%", "")):Object.keys(elems).length for (var e of table?(elems?.[a.qs("th", tr).textContent] ?? []):[tr]) { var grade1 = e.children[0].childNodes[ e.children[0].childNodes.length - 1 ] var grade2 = e.children[1] if (!grade2) { grade2 = grade1 grade1 = null } var g1num, g2num if (grade1) grade1.textContent = ( (g1num = Number( a .qs(".original_score", e.nextElementSibling) .textContent.trim() ) * val) / 100 ).toFixed(2) grade2.textContent = "/ " + ( (g2num = Number( grade2.textContent.replace(/\/ /, "").trim() // a // .qs(".original_points", e.nextElementSibling) // .textContent.trim() ) * val) / 100 ).toFixed(2) if ( a .qs(".original_points", e.nextElementSibling) .textContent.trim() == 0 ) { e.parentElement.parentElement.parentElement.style.display = "none" } else { grade1.parentElement.parentElement.parentElement.parentElement.appendChild( newHealthBar(g1num, g2num) ) } } } await a.waituntil(() => a .qsa(".grade") .find((e) => /^\s*\d+(?:\.\d+)%\s*$/.test(e.textContent)) ) a.qsa(".grade") .filter((e) => /^\s*\d+(?:\.\d+)%\s*$/.test(e.textContent)) .forEach((e) => { e.parentElement.parentElement.parentElement.appendChild( newHealthBar( Number(e.textContent.replace("%", "").trim()), 100 ) ) }) function newHealthBar(val, max) { return a.newelem( "div", { width: "calc(100% - 2px)", height: "20px", backgroundColor: "#a00", }, [ a.newelem("div", { boxShadow: "0 0 2px 1px #0a0", width: "calc(" + a.rerange(val, 0, max, 0, 100) + "% - 2px)", backgroundColor: "#0a0", height: "18px", position: "relative", left: "1px", top: "1px", }), ] ) } } })()