// ==UserScript==
// @name 萌娘百科增强
// @namespace github.com/hmjz100
// @author hmjz100
// @version 0.6
// @description 自用脚本,萌娘百科更换主题为紫色,黑幕转淡紫幕,链接与选中文本变紫色
// @license MIT
// @match http*://*.moegirl.org/*
// @match http*://*.moegirl.org/*
// @match http*://*.moegirl.org.cn/*
// @match http*://*.moegirl.org.cn/*
// @grant GM_addStyle
// @icon 
// @require https://unpkg.com/jquery@3.6.3/dist/jquery.min.js
// ==/UserScript==
(function moegirl() {
let colored = false
var base = {
// 动态添加样式
addStyle(id, tag, css, element, position) {
tag = tag || 'style';
element = element || 'body';
let styleDom = document.getElementById(id);
if (styleDom) styleDom.remove();
let style = document.createElement(tag);
style.rel = 'stylesheet';
style.id = id;
tag === 'style' ? style.innerHTML = css : style.href = css;
if (position === "before") {
$(element).prepend($(style));
} else {
$(element).append($(style));
}
},
hexToRgba(hex) {
// 去掉 # 号
hex = hex.replace(/^#/, '');
// 如果是四位十六进制颜色值,转换为八位
if (hex.length === 4) {
hex = hex[0] + hex[0] + hex[1] + hex[1] + hex[2] + hex[2] + hex[3] + hex[3];
}
// 解析 RGB 分量
var r = parseInt(hex.substring(0, 2), 16);
var g = parseInt(hex.substring(2, 4), 16);
var b = parseInt(hex.substring(4, 6), 16);
var a = '';
// 如果是八位十六进制颜色值,解析 alpha 通道
if (hex.length === 8) {
var a = 1;
a = parseInt(hex.substring(6, 8), 16) / 255; // 将 alpha 值转换为 0 到 1 之间的小数
a = ',' + a
}
// 返回 rgba 格式字符串
return r + ', ' + g + ', ' + b + a;
},
replaceColors(cssText, baseURI, type, colorMap) {
if (!cssText) return '';
if (type === 'other') {
// 遍历颜色映射数组,将旧颜色替换为新颜色,并添加过渡效果
colorMap.forEach(function (colorPair) {
var oldColor = colorPair[0];
var newColor = colorPair[1];
// 判断新颜色是否为 color
cssText = cssText.replace(new RegExp(oldColor, 'ig'), newColor);
});
return cssText;
}
if (colorMap) {
// 遍历颜色映射数组,将旧颜色替换为新颜色,并添加过渡效果
colorMap.forEach(function (colorPair) {
var oldColor = colorPair[0];
var newColor = colorPair[1];
// 判断新颜色是否为 color
if (oldColor.includes("#")) {
cssText = cssText.replace(new RegExp(oldColor + '(.*?)}', 'ig'), newColor + '$1; ' + 'transition: all 0.1s ease;}');
} else {
cssText = cssText.replace(new RegExp(oldColor, 'ig'), newColor);
}
});
};
if (baseURI) {
// 替换相对路径资源为绝对路径
cssText = cssText.replace(/url\((?!['"]?(?:data|https?):)['"]?([^'"\)]*)['"]?\)/ig, function (match, p1) {
// 如果URL是相对路径,则将其转换为绝对路径
var absoluteURL = new URL(p1, baseURI).href;
return 'url(' + absoluteURL + ')';
});
};
return cssText;
},
setColors(colorMap, type) {
let cssText
document.querySelectorAll('link[rel="stylesheet"]').forEach(function (tag) {
if (!tag.parentElement) return;
// 对于link标签,异步获取其CSS内容
fetch(tag.href)
.then(response => response.text())
.then(responseText => {
let id = 'Moegirl-Replace-Color-' + tag.href
// 替换颜色并添加样式
cssText = base.replaceColors(responseText, tag.href, type, colorMap);
if (responseText === base.replaceColors(responseText, '', type, colorMap)) return;
let newStyle = document.createElement('style');
newStyle.id = id;
newStyle.textContent = responseText;
if (location.pathname.includes("youth/pan")) {
base.addStyle(id, 'style', cssText, 'body', "before");
tag.remove()
} else {
base.addStyle(id, 'style', cssText, tag.parentElement.tagName || 'body');
}
console.log(`【(改)网盘直链下载助手】UI\n修改 <link> 元素 转 <style> 元素 样式\n元素:`, tag, `\n样式:`, newStyle);
});
})
document.querySelectorAll('[id^="Moegirl-Replace-Color-"]').forEach(function (tag) {
if (!tag.parentElement) return;
let id = tag.id;
let parent = tag.parentElement;
let element = parent.tagName || 'head';
// 替换颜色并添加样式
if (
tag.innerText === base.replaceColors(tag.innerText, '', type, colorMap)
) return;
cssText = base.replaceColors(tag.innerText, '', type, colorMap);
let newStyle = document.createElement('style');
newStyle.id = id;
newStyle.textContent = cssText;
base.addStyle(id, 'style', cssText, element);
console.log(`【(改)网盘直链下载助手】UI\n修改 Moegirl-Replace-Color <style> 元素 样式\n元素:`, tag, `\n样式:`, newStyle);
});
let count = 0;
if (!colored) {
base.waitForKeyElements('style', function (tag) {
tag = tag[0]
if (!tag.parentElement) return;
let id = tag.id;
let parent = tag.parentElement;
let element = parent.tagName || 'head';
// 替换颜色并添加样式
if (
id.includes('Moegirl-Replace-Color') ||
id.includes('swal-pub') ||
tag.innerText === base.replaceColors(tag.innerText, '', type, colorMap)
) return;
id = id ? id : `Moegirl-Replace-Color-${count++}`
cssText = base.replaceColors(tag.innerText, '', type, colorMap);
tag.id = id;
tag.textContent = cssText;
console.log(`【(改)网盘直链下载助手】UI\n修改 <style> 元素 样式\n元素:`, tag/*, `\n样式:`, newStyle*/);
})
colored = true;
}
},
waitForKeyElements(selectorTxt, actionFunction, bWaitOnce, iframeSelector) {
var targetbadges, btargetsFound;
if (typeof iframeSelector == "undefined")
targetbadges = $(selectorTxt);
else
targetbadges = $(iframeSelector).contents().find(selectorTxt);
if (targetbadges && targetbadges.length > 0) {
btargetsFound = true;
targetbadges.each(function () {
var jThis = $(this);
var alreadyFound = jThis.data('alreadyFound') || false;
if (!alreadyFound) {
var cancelFound = actionFunction(jThis);
if (cancelFound) {
btargetsFound = false;
} else {
jThis.data('alreadyFound', true);
}
}
});
} else {
btargetsFound = false;
}
var controlObj = base.waitForKeyElements.controlObj || {};
var controlKey = selectorTxt.replace(/[^\w]/g, "_");
var timeControl = controlObj[controlKey];
if (btargetsFound && bWaitOnce && timeControl) {
clearInterval(timeControl);
delete controlObj[controlKey];
} else {
if (!timeControl) {
timeControl = setInterval(function () {
base.waitForKeyElements(selectorTxt, actionFunction, bWaitOnce, iframeSelector);
}, 1);
controlObj[controlKey] = timeControl;
}
}
base.waitForKeyElements.controlObj = controlObj;
}
}
base.setColors([
['#0645ad', `#574AB8`],
['#228B22', `#574AB8`],
['#23a55e', `#574AB8`],
['#0c0', `#574AB8`],
['#DEEDE0', `#DDDCEF`],
['#73B839', `#574AB8D0`],
['#0b0080', `#7367F0`],
['#252525', `#ffffff`],
['#0074F9', `#574AB8`],
['#2bd155', `#7367F0`],
['#18a058', `#574AB8`],
['#36ad6a', `#574AB8`],
['#a7d7f9', `#574AB8D0`],
['#219e40', `#574AB8D0`],
['lightblue', `#ffffffD0`],
['MediumSeaGreen', `#574AB8D0`],
['green', `#574AB8`],
['#36c', `#574AB8`],
['#447ff5', `#7367F0`],
['#2a4b8d', `#574AB8D0`],
['#eaf3ff', `#DDDCEF`],
['37, 180, 73', base.hexToRgba(`#574AB8`)],
['62, 201, 97', base.hexToRgba(`#7367F0`)],
['70, 179, 84', base.hexToRgba(`#574AB8D0`)],
['35, 165, 94', base.hexToRgba(`#574AB8`)],
['167 215 249', base.hexToRgba(`#574AB8D0`)],
['235,249,234', base.hexToRgba(`#DDDCEF`)],
['225, 240, 230', base.hexToRgba(`#DDDCEF`)],
['0,200,0,0.1', base.hexToRgba(`#DDDCEF`)],
['163,270,71,0.1', base.hexToRgba(`#574AB81A`)],
['24, 160, 88, .16', base.hexToRgba(`#574AB830`)],
], 'other')
base.waitForKeyElements('a[href]', function (element) {
element.off('mousemove');
element.off('mouseover');
element[0].removeEventListener('mousemove');
element[0].removeEventListener('mouseover');
})
base.waitForKeyElements('[data-name="legacy"]', function (element) {
element.click()
})
base.waitForKeyElements('body.sideBarPic-executed.show-logo:not(.DeceasedPerson) #mw-panel #p-logo .mw-wiki-logo', function (element) {
element.removeAttr("style")
})
base.waitForKeyElements('[title*="你知道的太多了"][class]', function (element) {
element.removeAttr("title")
})
base.waitForKeyElements('del, [style="text-decoration: line-through;"], .just-kidding-text', function (element) {
element.css({ "text-decoration-thickness": "0.1px" })
})
base.waitForKeyElements('span[style*="background:"][style*="color:"]', function (element) {
element.addClass("heibox")
})
base.waitForKeyElements('.hover-change', function (element) {
element.attr("style", "padding-bottom:10px")
element.children().attr("class", "")
element.children().attr("style", "")
})
base.waitForKeyElements('.n-message-container.n-message-container--top .n-message-wrapper .n-message', function (element) {
if (element.find('.n-message__content .items-center').text().includes("订阅萌娘百科推送服务")) {
element.parent().toggle()
element.find('button.n-base-close[aria-label="close"]').click()
}
})
base.waitForKeyElements('aside#moe-global-siderail div.inner-wrapper div.moe-siderail-sticky', function (element) {
var timebar = $(`
<div class="moe-card" id="moe-siderail-sitenotice">
<div class="moe-wikitext-output"><h3 id="moegirlGreeting" style="margin-top: 0px;">你好呀</h3></div>
<ul style="text-align:center">
<li>感谢您使用本脚本,现在是</li>
<li><a id="moegirlTime"></a></li>
</ul>
</div>`);
element.prepend(timebar)
window.setInterval(function () {
timebar.find("#moegirlTime").text(Time());
timebar.find("#moegirlGreeting").text(Greeting());
}, 500);
})
base.waitForKeyElements('#localNotice[lang="zh"] .mw-parser-output', function (element) {
var timebar = $(`<div><a id="moegirlGreeting"></a> ,现在是 <a id="moegirlTime"></a> 感谢您使用本脚本~</div>`);
element.prepend(timebar)
window.setInterval(function () {
timebar.find("#moegirlTime").text(Time());
timebar.find("#moegirlGreeting").text(Greeting());
}, 500);
})
let heimu = `
.heibox {
background-color: #574AB8D0;
color: #fffffff0;
padding: 0 5px;
margin: 0 5px;
cursor: default;
border-radius: 5px;
transition: all 0.13s linear;
}
.heimu, .heimu rt {
background-color: #574AB8D0;
color: #fffffff0;
padding: 0 5px;
margin: 0 5px;
cursor: default;
border-radius: 5px;
transition: all 0.13s linear;
}
span.heimu:hover, span.heimu:active {
background-color: #7367F0;
color: #ffffff;
}
.mw-parser-output .hovers-blur {
filter: blur(0.5px);
}
`;
base.addStyle("Moegirl-Replace-Color", "style", heimu)
function Time() {
function repair(i) {
if (i >= 0 && i <= 9) {
return "0" + i;
} else {
return i;
}
}
var date = new Date();
var year = date.getFullYear();
var month = repair(date.getMonth() + 1);
var day = repair(date.getDate());
var hours = repair(date.getHours() >= 12 ? date.getHours() - 12 : date.getHours());
var apm = date.getHours() >= 12 ? "下午 " : "上午 ";
var minute = repair(date.getMinutes());
var second = repair(date.getSeconds());
var curTime = year + "年 " + month + "月 " + day + "日 " + apm + hours + "时 : " + minute + "分 : " + second + "秒";
return curTime;
}
function Greeting() {
var date = new Date();
var hour = date.getHours();
var greeting = '';
if (hour >= 0 && hour <= 10) {
greeting = '早上好';
} else if (hour > 10 && hour <= 14) {
greeting = '中午好';
} else if (hour > 14 && hour <= 18) {
greeting = '下午好';
} else if (hour > 18 && hour <= 24) {
greeting = '晚上好';
}
return greeting;
}
})();