您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
A Enhancer for Blackboard
// ==UserScript== // @name BlackBoard Enhancer // @namespace https://github.com/frank-xjh/BBEnhancer // @homepageURL https://github.com/frank-xjh/BBEnhancer // @supportURL https://github.com/frank-xjh/BBEnhancer/issues // @version 0.3 // @description A Enhancer for Blackboard // @author Frank // @match https://learn.intl.zju.edu.cn/* // @icon  // @grant none // ==/UserScript== (function () { 'use strict'; let listItems = document.querySelectorAll('li'); listItems.forEach(item => { let img = item.querySelector('img[alt="File"]'); if (img) { let anchor = item.querySelector('a'); if (anchor && anchor.hasAttribute('onclick')) { anchor.removeAttribute('onclick'); anchor.setAttribute('target', '_blank'); } } }); // Locate the course menu container const course = document.getElementById('courseMenu_link'); const menu = document.querySelector('#courseMenuPalette_contents'); if (!course || !menu) { console.warn('Course Not Found'); return; } const textContent = course.textContent; const pattern = /(.+):/; const match = textContent.match(pattern); if (match) { const courseCode = match[1] console.log('Course Code: ' + courseCode); const existingItem = document.querySelector('#paletteItem-similar-courses'); if (!existingItem) { // Create a new menu const newItem = document.createElement('li'); newItem.className = 'clearfix'; newItem.id = 'paletteItem-similar-courses'; // Create a new <a> element inside the <li> newItem.innerHTML = ` <a href="#"> <span title="Similar Courses">Similar Courses</span> </a> `; menu.appendChild(newItem); console.log('Similar Courses Menu Added'); // Add click event to the link newItem.querySelector('a').addEventListener('click', async function (e) { e.preventDefault(); await handleCourseSearch(courseCode); }); } } else { console.warn('Course Code Not Found'); } async function handleCourseSearch(courseCode) { const targetUrl = '/webapps/blackboard/execute/viewCatalog'; const body = new URLSearchParams({ type: 'Course', command: 'NewSearch', searchText: courseCode }); try { const response = await fetch(targetUrl, { method: 'POST', headers: { 'Content-Type': 'application/x-www-form-urlencoded' }, body: body.toString() }); if (response.ok) { const responseText = await response.text(); console.log('Search Successful'); const tempDiv = document.createElement('div'); tempDiv.innerHTML = responseText; const containerDiv = tempDiv.querySelector('#containerdiv'); if (containerDiv) { const links = containerDiv.querySelectorAll('a'); links.forEach(link => { link.target = '_blank'; }); // Replace const targetContainer = document.querySelector('#content'); if (targetContainer) { targetContainer.innerHTML = ` <div id="pageTitleDiv" class="pageTitle clearfix"> <div id="pageTitleBar" class="pageTitleIcon" tabindex="0"> <h1 id="pageTitleHeader" tabindex="-1"> <span id="pageTitleText">Similar Courses</span> </h1> <span id="_titlebarExtraContent" class="titleButtons"></span> </div> </div> `; targetContainer.appendChild(containerDiv); document.querySelector('#crumb_2').innerHTML = 'Similar Courses'; console.log('Content Replaced'); } else { console.error('Replaced Failed'); } } else { console.error('Container Not Found'); } } else { console.error('Search Failed:', response.status); } } catch (error) { console.error('Error Searching:', error); } } })();