云南大学校园网美化

云南大学自助服务平台(校园网)美化脚本

目前为 2024-02-11 提交的版本。查看 最新版本

// ==UserScript==
// @name         云南大学校园网美化
// @namespace    http://tampermonkey.net/
// @version      1.1.1
// @license      GPL-3.0
// @description  云南大学自助服务平台(校园网)美化脚本
// @author       Steven-Zhl
// @icon         https://selfsrv.ynu.edu.cn/favicon.ico
// @match        https://selfsrv.ynu.edu.cn/*
// @exclude      https://selfsrv.ynu.edu.cn/login
// @grant        none
// ==/UserScript==

function multiplyHexColor(hexColor, multipliers) {
    // 首先将16进制颜色值转换为RGB色值
    const r = parseInt(hexColor.slice(1, 3), 16);
    const g = parseInt(hexColor.slice(3, 5), 16);
    const b = parseInt(hexColor.slice(5, 7), 16);
    // 分别将RGB色值与倍率相乘,并确保结果在0到255之间
    const multipliedR = Math.min(255, Math.max(0, Math.round(r * multipliers[0])));
    const multipliedG = Math.min(255, Math.max(0, Math.round(g * multipliers[1])));
    const multipliedB = Math.min(255, Math.max(0, Math.round(b * multipliers[2])));
    // 将新的RGB值转换为16进制颜色值并返回
    const resultColor = `#${(multipliedR < 16 ? '0' : '') + multipliedR.toString(16)}${(multipliedG < 16 ? '0' : '') + multipliedG.toString(16)}${(multipliedB < 16 ? '0' : '') + multipliedB.toString(16)}`;
    return resultColor;
}
function queryImage(titleInfo, local_variableName) {
    var dialog = document.createElement('dialog'); dialog.style.cssText = "border-radius: 10px; padding: 10px; text-align: center;";
    var title = document.createElement('h3'); title.innerText = titleInfo; title.style.cssText = "text-align: center; margin: 3px";
    var type_container = document.createElement('div'); type_container.style.margin = "3px";
    var button_container = document.createElement('div'); button_container.style.cssText = "height: 30px; margin: 3px; text-align: center";
    var tip = document.createElement('p'); tip.innerText = "图片类型: "; tip.style.cssText = "display: inline-block; vertical-align: middle; margin: 3px";
    var select = document.createElement('select'); select.title = "选择图片"; select.style.cssText = "display: inline-block; vertical-align: middle; margin: 3px";
    select.innerHTML = '<option value="local">本地图片</option><option value="online">在线图片</option>';
    var local_input = document.createElement('input'); local_input.type = 'file'; local_input.accept = "image/png, image/jpg, image/jpeg"; local_input.style.margin = "3px";
    var online_input = document.createElement('input'); online_input.type = 'hidden'; online_input.placeholder = "请粘贴图片链接"; online_input.style.margin = "3px";
    var yesButton = document.createElement('button'); yesButton.innerText = '确定'; yesButton.style.cssText = "display: inline-block; margin: 3px";
    var clearButton = document.createElement('button'); clearButton.innerText = '恢复默认'; yesButton.style.cssText = "display: inline-block; margin: 3px";
    var cancelButton = document.createElement('button'); cancelButton.innerText = '取消'; cancelButton.style.cssText = "display: inline-block; margin: 3px";
    dialog.className = 'dialog';
    dialog.appendChild(title);
    dialog.appendChild(type_container);
    dialog.appendChild(local_input);
    dialog.appendChild(online_input);
    dialog.appendChild(button_container);
    type_container.appendChild(tip);
    type_container.appendChild(select);
    button_container.appendChild(yesButton);
    button_container.appendChild(cancelButton);
    button_container.appendChild(clearButton);
    // 添加事件监听器
    select.addEventListener('change', function () {
        if (select.value === 'local') { local_input.type = 'file'; online_input.type = 'hidden'; }
        else if (select.value === 'online') { local_input.type = 'hidden'; online_input.type = 'text'; }
    });
    yesButton.addEventListener('click', function () {
        if (select.value === 'local' && local_input.files[0]) {
            const reader = new FileReader();
            reader.onload = function () {
                const img = new Image(); // 创建一个新的Image对象
                img.src = reader.result; // 设置Image对象的src为用户输入的文件链接
                try { localStorage.setItem(local_variableName, reader.result); }
                catch (e) { alert('图片文件过大,无法加载'); dialog.close(); }
            };
            reader.readAsDataURL(local_input.files[0]);
            window.location.reload();
        } else if (select.value === 'online') { localStorage.setItem(local_variableName, online_input.value); }

    });
    clearButton.addEventListener('click', function () {
        localStorage.removeItem(local_variableName);
        alert('已恢复默认');
        window.location.reload();
    });
    cancelButton.addEventListener('click', function () { dialog.close(); });
    document.body.appendChild(dialog);
    dialog.showModal();
}
function queryColor(titleInfo, local_variableName) {
    var dialog = document.createElement('dialog'); dialog.style.cssText = "border-radius: 10px; padding: 10px; text-align: center;";
    var title = document.createElement('h3'); title.innerText = titleInfo; title.style.cssText = "text-align: center; margin: 3px";
    var button_container = document.createElement('div'); button_container.style.cssText = "height: 30px; margin: 3px; text-align: center";
    var input = document.createElement('input'); input.type = 'color'; input.style.margin = "3px";
    var yesButton = document.createElement('button'); yesButton.innerText = '确定'; yesButton.style.cssText = "display: inline-block; margin: 3px";
    var clearButton = document.createElement('button'); clearButton.innerText = '恢复默认'; yesButton.style.cssText = "display: inline-block; margin: 3px";
    var cancelButton = document.createElement('button'); cancelButton.innerText = '取消'; cancelButton.style.cssText = "display: inline-block; margin: 3px";
    dialog.className = 'dialog';
    dialog.appendChild(title);
    dialog.appendChild(input);
    dialog.appendChild(button_container);
    button_container.appendChild(yesButton);
    button_container.appendChild(cancelButton);
    button_container.appendChild(clearButton);
    yesButton.addEventListener('click', function () {
        localStorage.setItem(local_variableName, input.value);
        window.location.reload();
    });
    clearButton.addEventListener('click', function () {
        localStorage.removeItem(local_variableName);
        alert('已恢复默认');
        window.location.reload();
    });
    cancelButton.addEventListener('click', function () { dialog.close(); });
    document.body.appendChild(dialog);
    dialog.showModal();
}
function loadThemeColor(themeColor) { // 将颜色替换为自定义主题色
    var headerColor = multiplyHexColor(themeColor, [115 / 60, 202 / 141, 226 / 188]);
    var logoColor = multiplyHexColor(themeColor, [54 / 60, 127 / 141, 169 / 188]);
    var header = document.getElementsByClassName("navbar navbar-static-top")[0];
    var sidebar = document.getElementsByClassName('sidebar-menu')[0];
    header.style.backgroundColor = themeColor;
    header.style.backgroundImage = 'linear-gradient(to right, ' + themeColor + ', ' + headerColor + ')';
    sidebar.getElementsByClassName('active')[0].firstChild.style.borderLeftColor = themeColor; // 修改sidebar的active元素的左边框颜色
    document.getElementsByClassName('logo')[0].style.backgroundColor = logoColor; // 修改logo的背景颜色
    document.getElementsByClassName('sidebar-toggle')[0].style.backgroundColor = themeColor; // 修改sidebar-toggle的背景颜色
    document.getElementsByClassName('user-header')[0].style.backgroundColor = themeColor; // 修改user-header的背景颜色
    document.getElementsByClassName('main-footer')[0].style.backgroundColor = themeColor; // 修改main-footer的背景颜色
}
function loadSidebarColor(sidebarColor) {
    var sidebar = document.getElementsByClassName('sidebar-menu')[0];
    document.getElementsByClassName('main-sidebar')[0].style.backgroundColor = sidebarColor;
    document.querySelectorAll('.treeview-menu').forEach(function (treeview_menu) { treeview_menu.style.backgroundColor = sidebarColor; }); // 修改treeview-menu的背景颜色
    sidebar.style.color = sidebarColor;
    sidebar.querySelectorAll('li').forEach(function (li) {
        li.style.backgroundColor = sidebarColor;
        li.style.color = sidebarColor;
        if (li.firstChild.firstChild) { li.firstChild.style.backgroundColor = sidebarColor; }
    });
}
function loadAvatar(avater_link) { // 将图片链接替换为自定义头像
    if (!avater_link) { return; }
    var avatar = document.getElementsByClassName('img-circle');
    for (let i = 0; i < avatar.length; i++)  avatar[i].src = avater_link;
    document.getElementsByClassName('user-image')[0].src = avater_link;
}
function loadBackground(background_link) { // 将图片链接替换为自定义背景图片
    if (!background_link) { return; }
    var backgroundElement = document.getElementsByClassName('content-wrapper')[0];
    backgroundElement.style.background = 'url(' + background_link + ')';
    backgroundElement.style.backgroundSize = 'cover';
    // 为了更好显示背景图片,需要让页面中的panel和panel-heading元素半透明
    document.querySelectorAll('.panel').forEach(function (panel) { panel.style.opacity = '0.75'; });
    document.querySelectorAll('.panel-heading').forEach(function (panel) { panel.style.opacity = '0.75'; });
}
function genshin_theme() { // 加载原神主题
    loadBackground('https://ys.mihoyo.com/main/_nuxt/img/47f71d4.jpg');
    loadAvatar('https://uploadstatic.mihoyo.com/contentweb/20210105/2021010518424084444.png');
    loadThemeColor("#404040a0");
    loadSidebarColor("#404040");
    var badge = document.createElement('img');
    badge.src = '';
    badge.style.cssText = "position: fixed; bottom: 80px; right: 20px; width: 60px; height: auto;"
    document.body.appendChild(badge);
    document.getElementsByClassName('logo-lg')[0].firstChild.innerText = "云·原神";
    document.getElementsByClassName('logo-mini')[0].innerHTML = '<img src="https://webstatic.mihoyo.com/bh3/upload/officialsites/201908/ys_1565764084_7084.png" width="40px">';
    var icon = document.createElement('link'); icon.rel = 'icon'; icon.type = 'image/ico'; icon.href = 'https://ys.mihoyo.com/main/favicon.ico';
    document.head.appendChild(icon);
    document.getElementsByClassName('text-success')[0].parentElement.innerHTML = '<i class="fa fa-circle text-success"></i>提瓦特大陆';
}

(function () {
    // 1. 在首页和/在线信息和日志/上网明细中,同步来自无感知认证的备注
    if (window.location.href == 'https://selfsrv.ynu.edu.cn/home' || window.location.href.match('https:\/\/selfsrv\.ynu\.edu\.cn\/log\/detail.*')) {
        fetch('https://selfsrv.ynu.edu.cn/user/mac-auth')
            .then(response => {
                if (!response.ok) { throw new Error('网络请求失败'); }
                return response.text();
            })
            .then(html => {
                const tempDiv = document.createElement('div');// 创建一个临时div元素来解析HTML
                tempDiv.innerHTML = html;
                const mac_list = tempDiv.querySelector('.kv-grid-table.table.table-hover.table-bordered').querySelectorAll('tr');
                if (mac_list) {// 获取 mac地址-备注 的字典
                    var mac_dict = {};
                    var macElements = Array.from(mac_list).slice(1); // 跳过第一个元素
                    macElements.forEach(function (macElement) {
                        mac_dict[macElement.querySelectorAll('td')[1].innerText] = macElement.querySelectorAll('td')[2].querySelector('.kv-editable-link').innerText;
                    });
                    if (window.location.href == 'https://selfsrv.ynu.edu.cn/home') {
                        // 将其添加到首页的在线信息中
                        var online_table = document.getElementsByClassName('kv-grid-table table table-bordered table-striped')[0];
                        var online_table_header = document.getElementsByClassName('kv-table-header w1')[0];
                        online_table_header.getElementsByTagName('tr')[0].innerHTML = '<th>设备备注</th>' + online_table_header.getElementsByTagName('tr')[0].innerHTML;
                        var online_list = online_table.getElementsByTagName('tbody')[0];
                        for (let i = 0; i < online_list.getElementsByTagName('tr').length; i++) {
                            var mac_addr = online_list.getElementsByTagName('tr')[i].getElementsByTagName('td')[5].innerText;
                            if (mac_addr in mac_dict) { online_list.getElementsByTagName('tr')[i].innerHTML = '<td>' + mac_dict[mac_addr] + '</td>' + online_list.getElementsByTagName('tr')[i].innerHTML; }
                            else { online_list.getElementsByTagName('tr')[i].innerHTML = '<td></td>' + online_list.getElementsByTagName('tr')[i].innerHTML; }
                        }
                    } else if (window.location.href.match('https:\/\/selfsrv\.ynu\.edu\.cn\/log\/detail.*')) {
                        // 将其添加到日志/上网明细中
                        var log_table = document.getElementsByClassName('kv-grid-table table table-hover table-bordered')[0];
                        var log_table_header = document.getElementsByClassName('kv-table-header w0')[0];
                        log_table_header.getElementsByTagName('tr')[0].innerHTML = '<th>设备备注</th>' + log_table_header.getElementsByTagName('tr')[0].innerHTML;
                        var log_list = log_table.getElementsByTagName('tbody')[0];
                        for (let i = 0; i < log_list.getElementsByTagName('tr').length; i++) {
                            var mac_addr = log_list.getElementsByTagName('tr')[i].getElementsByTagName('td')[3].innerText;
                            if (mac_addr in mac_dict) {
                                log_list.getElementsByTagName('tr')[i].innerHTML = '<td>' + mac_dict[mac_addr] + '</td>' + log_list.getElementsByTagName('tr')[i].innerHTML;
                            } else {
                                log_list.getElementsByTagName('tr')[i].innerHTML = '<td></td>' + log_list.getElementsByTagName('tr')[i].innerHTML;
                            }
                        }
                    }
                } else { console.error('未找到目标元素'); }
            })
            .catch(error => {
                console.error('Error:', error);
            });
    }
    var sidebar = document.getElementsByClassName('sidebar-menu')[0];
    // 2. 自定义主题色
    var local_themeColor = localStorage.getItem('YNU-selfsrv-enhance-theme-color') ? localStorage.getItem('YNU-selfsrv-enhance-theme-color') : "#3c8dbc"; // 获取先前已设置的主题色
    var themeColor_button = document.createElement('li');// “自定义主题色”按钮
    themeColor_button.className = 'treeview';
    themeColor_button.innerHTML = '<a href="#" title="自定义主题色" ><i class="glyphicon glyphicon-heart"></i><span>自定义主题色</span></a>';
    themeColor_button.addEventListener('click', function () { queryColor("请选择主题色", 'YNU-selfsrv-enhance-theme-color'); });
    sidebar.appendChild(themeColor_button);
    loadThemeColor(local_themeColor);
    // 3. 自定义侧边栏颜色
    var local_siderbarColor = localStorage.getItem('YNU-selfsrv-enhance-sidebar-color') ? localStorage.getItem('YNU-selfsrv-enhance-sidebar-color') : "#222d32"; // 获取先前已设置的侧边栏颜色
    var sidebarColor_button = document.createElement('li');
    sidebarColor_button.className = 'treeview';
    sidebarColor_button.innerHTML = '<a href="#" title="自定义侧边栏颜色" ><i class="glyphicon glyphicon-tag"></i><span>自定义侧边栏颜色</span></a>';
    sidebarColor_button.addEventListener('click', function () { queryColor("请选择侧边栏颜色", 'YNU-selfsrv-enhance-sidebar-color'); });
    sidebar.appendChild(sidebarColor_button);
    loadSidebarColor(local_siderbarColor);
    // 4. 自定义头像
    var local_avater_link = localStorage.getItem('YNU-selfsrv-enhance-avatar-link'); // 获取先前已设置的头像链接
    var avatar_button = document.createElement('li');// “更换头像”按钮
    avatar_button.className = 'treeview';
    avatar_button.innerHTML = '<a href="#" title="更换头像" ><i class="glyphicon glyphicon-user"></i><span>更换头像</span></a>';
    avatar_button.style.backgroundColor = local_siderbarColor;
    avatar_button.style.color = local_siderbarColor;
    avatar_button.firstChild.style.backgroundColor = local_siderbarColor;
    avatar_button.addEventListener('click', function () { queryImage("选择头像图片", "YNU-selfsrv-enhance-avatar-link"); });
    sidebar.appendChild(avatar_button);
    if (local_avater_link) { loadAvatar(local_avater_link); }
    // 5. 自定义背景图片
    var local_background_link = localStorage.getItem('YNU-selfsrv-enhance-background-link'); // 获取先前已设置的背景图片链接
    var background_button = document.createElement('li');// “更换背景图片”按钮
    background_button.className = 'treeview';
    background_button.innerHTML = '<a href="#" title="更换背景图片" ><i class="glyphicon glyphicon-picture"></i><span>更换背景图片</span></a>';
    background_button.style.backgroundColor = local_siderbarColor;
    background_button.style.color = local_siderbarColor;
    background_button.firstChild.style.backgroundColor = local_siderbarColor;
    background_button.addEventListener('click', function () { queryImage("选择背景图片", "YNU-selfsrv-enhance-background-link"); });
    sidebar.appendChild(background_button);
    if (local_background_link) { loadBackground(local_background_link); }
    // 6. 原神,启动!
    var genshin_button = document.createElement('li');
    genshin_button.className = 'treeview';
    genshin_button.innerHTML = '<a href="#" title="原神,启动!" ><i class="glyphicon glyphicon-fire"></i><span>原神,启动!</span></a>';
    genshin_button.style.backgroundColor = local_siderbarColor;
    genshin_button.style.color = local_siderbarColor;
    genshin_button.firstChild.style.backgroundColor = local_siderbarColor;
    genshin_button.addEventListener('click', function () {
        if (!localStorage.getItem('YNU-selfsrv-enhance-genshin-mode')) {
            localStorage.setItem('YNU-selfsrv-enhance-genshin-mode', 'true');
            alert('原神,启动!');
        } else {
            localStorage.removeItem('YNU-selfsrv-enhance-genshin-mode');
            alert('原神,关闭!');
        }
        window.location.reload();
    });
    sidebar.appendChild(genshin_button);
    if (localStorage.getItem('YNU-selfsrv-enhance-genshin-mode')) { genshin_theme(); }
})();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址