// ==UserScript==
// @name Steam增强器
// @namespace http://tampermonkey.net/
// @version 1.4
// @description 该脚本能够放大Steam平台的大部分界面元素,提升阅读和操作体验;在CSGO社区市场详情页显示Buff平台的价格对比并提供跳转链接,方便用户快速查看和购买;同时在游戏详情页添加快捷跳转按钮,连接到小黑盒和SteamDB,帮助用户快速获取更多游戏相关信息和数据分析
// @author Mr.Wan
// @homepageURL https://github.com/wanbage8/SteamPlus
// @icon 
// @license GPL-3.0 License
// @match *://store.steampowered.com/*
// @match *://steamcommunity.com/*
// @grant GM_addStyle
// @grant GM_xmlhttpRequest
// @connect steamcommunity.com
// @connect buff.163.com
// @connect api.steampowered.com
// @connect steamcharts.com
// @connect xiaoheihe.cn
// ==/UserScript==
(function () {
GM_addStyle(`
* {
transition: var(--transition) var(--time)!important;
border-radius: var(--borderR) !important;
}
:root{
--mainWidth:64vw;
--mainMinWidth:940px;
--transition:.3s;
--borderR:5px;
--time:ease-in-out;
--csgoColor:#FFD700;
}
#Reviews_summary > div > div.leftcol {width:75%;}
.rightcol.recent_reviews {width:calc(25% - 14px);}
.review_box > div > .rightcol {width:calc(100% - 226px);}
#highlight_strip_scroll,
.forum_topic_tooltip {transition:0s !important;}
.slider_ctn .handle, p {font-size: 15px;}
.but {
background-color: rgba(103, 193, 245, 0.2);
box-shadow: none;
margin-right: 2px;
border-radius: 2px;
cursor: pointer;
margin-bottom: 3px;
max-width: 200px;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
width: fit-content;
height: 30px;
display: flex;
align-items: center;
justify-content: center;
}
.wan-box {
position: fixed;
top: 25%;
left: 25%;
z-index: 999;
width: 350px;
padding: 10px;
background-color: #ffffff8a;
backdrop-filter: blur(5px);
display: none;
color: #000;
cursor: move;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
border: 1px solid #eee;
}
.switch-container {
margin-top: 20px;
}
.flex {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 5px;
}
.switch {
position: relative;
display: inline-block;
width: 53px;
height: 25px;
margin-left: 10px;
}
.switch input {
opacity: 0;
width: 0;
height: 0;
}
.sliderBut {
position: absolute;
cursor: pointer;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-color: #ccc;
transition: .4s;
border-radius: 34px;
}
.sliderBut:before {
position: absolute;
content: "";
height: 20px;
width: 20px;
left: 4px;
top: 50%;
transform: translateY(-50%);
background-color: #fff;
transition: .4s;
border-radius: 50%;
}
input:checked + .sliderBut {
background-color: #2196F3;
}
input:focus + .sliderBut {
box-shadow: 0 0 1px #2196F3;
}
input:checked + .sliderBut:before {
transform: translate(26px, -50%);
}
.output {
margin-top: 20px;
font-size: 18px;
}
.wan-box-footer {
display: flex;
align-items: center;
justify-content: space-around;
margin-top: 10px;
}
.button {
background-color: #2196F3;
border: none;
color: white;
padding: 5px 10px;
text-align: center;
text-decoration: none;
display: inline-block;
font-size: 16px;
margin: 4px 2px;
cursor: pointer;
border-radius: 5px;
transition: background-color 0.3s ease;
}
.button:hover {
background-color: #007BFF;
}
.button:active {
background-color: #0056b3;
transform: scale(0.98);
}
.title {
font-size: 14px;
font-weight: bold;
}
.radio-mar {
margin-left: 10px;
}
[type="range"] {
margin-left: 10px;
}
.community_home_header {
max-width: initial;
width: var(--mainWidth);
}
.community_home_tabs {
max-width: initial;
width: var(--mainWidth);
}
#AppHubContent {
max-width: initial;
width:var(--mainWidth);
}
#modalContent {
width:var(--mainWidth)!important;
}
.workshopItemControlsCtn.fixed_in_scroll#ScrollingItemControls {
width: var(--mainWidth);
margin:0 auto;
}
.apphub_HomeHeader,
div#store_header:not([aria-label="商店菜单"]) .content {
width: var(--mainWidth);
max-width: initial;
}
.Broadcast_Card.apphub_Card,
.Broadcast_Card .apphub_CardContentPreviewImage {
max-width:initial;
max-height:initial;
}
._2nl8HoZ_rxg3AGpYs0N_UD.Panel.Focusable,
.workshop_home_content{
width: var(--mainWidth);
max-width: initial;
}
.pagecontent #BG_bottom.maincontent {
width: var(--mainWidth)!important;
}
#tabs_basebg #leftContents {
width:80%;
max-width:initial;
}
#rightContents,
#rightContents.sidebar.right_column {
width:calc(20% - 10px);
max-width:initial;
}
.responsive_tab_baseline,
#mainContents,
#tabs_basebg,
#highlight_player_area,
.highlight_overflow,
.highlight_ctn,
#search_result_container,
div#store_header .content,
.slideshow_content,
.review_page_content{
max-width: initial;
}
.view_inventory_page .inventory_ctn,
.view_inventory_page .inventory_ctn .inventory_page,
.gameLogoHolder_default img{
width:100%
}
.trade_item_box {
background-color: initial;
}
#BG_top_workshop {
width: var(--mainWidth);
background-size:100%;
background-position: top;
}
.home_leftcol.home_tab_col {
width:80%;
}
.flex_cols > .home_leftcol {
width: 618px;
}
.home_rightcol {
width:19%;
}
#search_resultsRows a.search_result_row {
display: flex;
}
#search_resultsRows a.search_result_row .responsive_search_name_combined {
width: calc(85% - 125px);
display: flex;
align-items: center;
justify-content: space-between;
}
.search_result_row .col.search_released {
width: 106px;
flex-shrink: 0;
}
.left_column,
#leftContents{
width: 80%;
}
.right_column {
width:calc(20% - 10px);
}
.profile_subpage_column .maincontent, body.migrated_profile_page .profile_subpage_column #BG_bottom.maincontent {
background: rgb(18, 27, 37);
}
.profile_subpage_column .profile_small_header_bg {
background-image:initial;
}
.profile_flag,
.progress-bar{
border-radius: 0px !important;
}
.browse_content .recommendation .recommendation_link {
width: 100%;
}
.wear .wear-pointer .wear-pointer-icon {
margin-left: -6px;
position: absolute;
width: 0;
height: 0;
border-style: solid;
border-width: 6px 6px 0 6px;
border-color: #515151 transparent transparent transparent;
}
.wear-pointer {
width: 180px;
position: relative;
padding-bottom: 4px;
margin-top: 3px;
}
.progress {
overflow: hidden;
height: 5px;
width: 180px;
}
.progress {
height: 5px;
overflow: hidden;
background-color: #f5f5f5;
border-radius: 4px;
-webkit-box-shadow: inset 0 1px 2px rgba(0,0,0,.1);
box-shadow: inset 0 1px 2px rgba(0,0,0,.1);
box-sizing: border-box;
}
.wear-pointer-icon {
margin-left: -6px;
position: absolute;
width: 0;
height: 0;
border-style: solid;
border-width: 6px 6px 0 6px;
border-color: #515151 transparent transparent transparent;
}
.progress-bar {
float: left;
width: 0;
height: 100%;
font-size: 12px;
line-height: 20px;
color: #fff;
text-align: center;
background-color: #337ab7;
-webkit-transition: width .6s ease;
-o-transition: width .6s ease;
transition: width .6s ease;
}
.progress-bar-fn {
background-color: green;
}
.progress-bar-success {
background-color: #5cb85c;
}
.progress-bar-warning {
background-color: #f0ad4e;
}
.progress-bar-danger {
background-color: #d9534f;
}
.progress-bar-bs {
background-color: #993A38;
}
.sticker {
position: relative;
}
.sticker-2 {
background: #474747;
padding: 10px;
position: absolute;
top: -50%;
transform: translateY(60%);
left: 76%;
opacity: 0;
cursor: pointer;
}
.sticker-2::before {
content: '';
border:10px solid transparent;
border-right-color: #474747;
position: absolute;
top: 50%;
transform: translateY(-50%);
left: -20px;
}
.sticker:hover img {
width: 75px;
height: 75px;
}
.sticker:hover .sticker-2 {
opacity: 1;
}
.BUFF-active {
animation: borderColor 1s linear infinite;
border: var(--csgoColor) 2px solid;
}
@keyframes borderColor {
0%{
border-color: var(--csgoColor);
}
50%{
border-color: transparent;
}
100%{
border-color: var(--csgoColor);
}
}
#BUFF-up {
width: 35px;
height: 35px;
border-radius: 50%;
border: 1px solid var(--csgoColor);
display: flex;
align-items: center;
justify-content: center;
position: fixed;
right: -50px;
top: -50%;
transform: translateY(-50%);
opacity: 0;
}
`)
/*======修改页面宽度======*/
/*
* 规则集:
* 可自定义添加
* 类名:{
* css属性:值
* }
* */
let combinedRules = {
"div.leftcol": {
"width": "70%"
},
"div.rightcol": {
"width": "calc(30% - 14px)%"
},
"img.game_header_image_full": {
"width": "100%"
},
".queue_ctn": {
"width": "var(--mainWidth)"
},
".game_area_play_stats": {
"width": "var(--mainWidth)",
"max-width": "initial"
},
".leftcol.game_description_column": {
"width": "70%"
},
".rightcol.game_meta_data": {
"width": "calc(30% - 14px)"
},
"#review_create": {
"width": "100%",
"max-width": "initial"
},
".notice_box_content": {
"width": "calc(100% - 29px)"
},
"#game_recommendation": {
"width": "calc(100% - 27px)",
"max-width": "calc(100% - 27px)",
"transition": "initial !important"
},
".review_controls": {
"width": "calc(100% - 19px)",
"max-width": "calc(100% - 19px)"
},
".game_language_options": {
"width": "100%"
},
"body.v6 .page_content": {
"width": "var(--mainWidth)"
},
".game_page_background.game .responsive_store_nav_ctn_spacer #store_header .content": {
"width": "var(--mainWidth)"
},
".apphub_HomeHeaderContent": {
"max-width": "initial"
},
"#responsive_page_template_content .apphub_HomeHeaderContent": {
"width": "var(--mainWidth)",
"max-width": "initial"
},
".glance_tags.popular_tags": {
"display": "flex",
"flex-wrap": "wrap",
"height": "fit-content"
},
".similar_recent_apps_container": {
"height": "fit-content",
"flex-wrap": "wrap"
},
"#gameHeaderImageCtn img": {
"height": "auto",
"width": "100%"
},
".rightcol.small.responsive_local_menu.autocollapse_enabled#additional_search_options": {
"width": "calc(30% - 14px)",
},
"search_result_container": {
"max-width": "initial"
},
".page_content_ctn.friend_activity .page_content .rightcol": {
"width": "calc(30% - 14px)",
},
"#ig_bottom.nobg.mediaBody": {
"width": "var(--mainWidth)",
"max-width": "initial"
},
"#responsive_page_template_content .breadcrumbs": {
"width": "var(--mainWidth)",
"max-width": "initial"
},
"#ItemControls": {
"width": "initial",
"max-width": "initial"
},
"#profileBlock.clearfix": {
"width": "80%",
"max-width": "initial"
},
".subSection.detailBox": {
"background-position": "top",
"background-size": "100%",
},
".responsive_local_menu#rightContents": {
"width": "calc(20% - 10px)",
},
".responsive_local_menu#rightContents .sidebar": {
"width": "100%",
},
"#blotter_page": {
"width": "var(--mainWidth)",
},
"#blotter_content": {
"width": "80%",
},
"#friendactivity_right_column": {
"width": "20%",
},
".profile_small_header_bg": {
"width": "var(--mainWidth)",
"max-width": "initial"
},
".profile_small_header_texture": {
"max-width": "initial"
},
".maincontent": {
"width": "var(--mainWidth)",
},
"#active_inventory_page.view_inventory_page": {
"width": "initial",
},
".view_inventory_page .inventory_page_left": {
"width": "calc(100% - 360px)",
},
".view_inventory_page #inventories": {
"width": "calc(100% - 6px)"
},
".apphub_HomeHeader": {
"max-width": "initial"
},
"html.responsive #ig_bottom": {
"width": "var(--mainWidth)",
"max-width": "initial"
},
"#ig_bottom.smallheader": {
"width": "var(--mainWidth)",
"max-width": "initial"
},
".joinGroup": {
"width": "initial",
},
".workshop_header": {
"width": "var(--mainWidth)",
"margin": "0 auto",
},
".apphub_ContentGuides": {
"max-width": "initial",
"width": "80%"
},
"#game_highlights .rightcol": {
"width": "30%",
},
"#game_area_description": {
"width": "initial",
},
".apphub_HomeHeaderContent .apphub_AppIcon": {
"display": "block",
"float": "left",
"margin-right": "5px",
},
"#AppHubContent .maincontent .rightcol.responsive_local_menu": {
"width": "calc(30% - 18px)",
},
"#AppHubContent .rightcol.responsive_local_menu": {
"width": "calc(30% - 18px)",
},
".discussionSearchTextContainer": {
"background-size": "100% 100%",
"width": "100%",
},
".discussionSearchText.searchText": {
"width": "calc(100% - 80px)",
"left": "17px",
},
".discussionSearchTextSubmitImg": {
"left": "90%",
},
".forum_op": {
"max-width": "initial",
"background-size": "100%"
},
".creator_announcement_browse_adjustment .browse_container": {
"transform": "initial",
"width": "100%",
},
"body.v6.curator .page_content.browse_reviews": {
"transform": "translateX(-160px)",
},
".saleEventBannerBig": {
"width": "100%",
},
".saleEventBannerMobile": {
"width": "100%",
},
".game_area_description": {
"width": "100%",
},
".game_area_description img.bb_img": {
"width": "100%",
},
"#review_histogram_rollup_section": {
"width": "70%",
},
"#review_histogram_recent_section": {
"width": "30%",
}
};
function applyStyles(rules) {
for (let selector in rules) {
const elements = document.querySelectorAll(selector);
if (!elements || elements.length === 0) continue;
elements.forEach(element => {
let properties = rules[selector];
for (let property in properties) {
let value = properties[property];
if (value === undefined || value === null) continue;
element.style[property] = value;
}
});
}
}
applyStyles(combinedRules);
//======自定义页面======//
document.body.insertAdjacentHTML("beforeend", `<div class="wan-box" style="transition: 0s !important;"><h2 style="text-align: center;font-size: 26px;color: #000">Steam大屏Plus</h2><label for="range">页面宽度<input type="range" min="10" max="100" value="64" id="range"><span id="rangeNum">64</span><span id="unit">%视口宽度</span></label><div class="switch-container"><div class="flex"><span>是否启用全局圆角</span><label class="switch"><input type="checkbox" id="radius" checked><span class="sliderBut"></span></label></div><label for="radiusInp" title="设置圆角大小单位像素">圆角大小<input type="range" min="0" max="25" value="5" id="radiusInp"><span id="radiusNum">5</span>px</label></div><div class="switch-container"><div class="flex"><span>是否启用全局过渡</span><label class="switch"><input type="checkbox" id="transition" checked><span class="sliderBut"></span></label></div><label for="transitionInp" title="设置过渡时长单位秒(过渡时间过长可能导致某些元素响应慢)">过渡时长<input type="range" min="0" max="5" step="0.1" value="0.3" id="transitionInp"><span id="transitionNum">0.3</span>s<div>过渡曲线<label for="ease-in-out" class="radio-mar">快=>慢=>快<input type="radio" name="time" data-name="ease-in-out" id="ease-in-out" checked></label><label for="ease-out" class="radio-mar">慢=>快<input type="radio" name="time" data-name="ease-out" id="ease-out"></label><label for="linear" class="radio-mar">匀速<input type="radio" name="time" data-name="linear" id="linear"></label></div></label></div><div class="wan-box-footer"><button class="button" id="ok">确定</button><button class="button" id="no">取消</button><button class="button" id="reset" title="重置为Steam默认宽度">重置</button></div></div>`);
let ranges = document.querySelectorAll("input[type='range']");
let range = document.querySelector("#range");
let radiusInp = document.querySelector("#radiusInp");
let radius = document.querySelector("#radius");
let transitionInp = document.querySelector("#transitionInp");
let transition = document.querySelector("#transition");
let ok = document.querySelector("#ok");
let no = document.querySelector("#no");
let wanBox = document.querySelector(".wan-box");
let reset = document.querySelector("#reset");
let data = JSON.parse(localStorage.getItem("state"));
let unit = document.querySelector("#unit");
let timeOut = document.querySelectorAll("#transitionNum~div>label>input");
let steamURL = location.href
let num = 0;
let timeStatus = "ease-in-out"
let state;
let sw = {
radius: 1,
transition: 1
};
if (data) {
state = data
range.value = data.range;
document.getElementById("rangeNum").innerText = data.range;
radiusInp.value = data.radius;
document.getElementById("radiusNum").innerText = data.radius;
transitionInp.value = data.transition;
document.getElementById("transitionNum").innerText = data.transition;
document.documentElement.style.setProperty("--mainWidth", data.range + (data.range <= 100 ? "vw" : "px"));
document.documentElement.style.setProperty("--transition", data.transition + "s");
document.documentElement.style.setProperty("--borderR", data.radius + "px");
document.documentElement.style.setProperty("--time", data.time);
unit.innerText = state.range <= 100 ? "%视口宽度" : "px"
}
for (let i = 0; i < ranges.length; i++) {
ranges[i].addEventListener("input", function () {
this.nextElementSibling.innerHTML = this.value;
})
}
function toggleElement(ele) {
if (ele.checked) {
ele.parentElement.parentElement.nextElementSibling.style.display = "block";
sw[ele.id] = 1
} else {
ele.parentElement.parentElement.nextElementSibling.style.display = "none";
sw[ele.id] = 0
}
}
radius.addEventListener("change", function () {
toggleElement(this)
})
transition.addEventListener("change", function () {
toggleElement(this);
})
ok.addEventListener("click", function () {
state = {
range: range.value,
radius: sw.radius ? radiusInp.value : "0",
transition: sw.transition ? transitionInp.value : "0",
time: timeStatus,
}
localStorage.setItem("state", JSON.stringify(state));
wanBox.style.display = "none";
document.documentElement.style.setProperty("--mainWidth", state.range + "vw");
document.documentElement.style.setProperty("--transition", state.transition + "s");
document.documentElement.style.setProperty("--borderR", state.radius + "px");
document.documentElement.style.setProperty("--time", state.time);
num++
})
no.addEventListener("click", function () {
wanBox.style.display = "none";
num++
})
reset.addEventListener("click", function () {
state.range = "940"
localStorage.setItem("state", JSON.stringify(state));
wanBox.style.display = "none";
document.documentElement.style.setProperty("--mainWidth", state.range + "px");
num++
})
document.addEventListener("keyup", function (e) {
if (e.altKey && e.keyCode === 65 && e.ctrlKey) {
if (num % 2 === 0) {
wanBox.style.display = "block"
} else {
wanBox.style.display = "none"
}
num++
}
unit.innerText = state?.range <= 100 ? "%视口宽度" : "px"
})
let move = false;
let offset = [0, 0];
wanBox.addEventListener('mousedown', function (e) {
if (e.target !== this && !e.target.closest('input[type="range"]')) {
move = true;
offset = [
wanBox.offsetLeft - e.clientX,
wanBox.offsetTop - e.clientY
];
}
});
document.addEventListener('mousemove', function (e) {
if (move) {
e.preventDefault();
wanBox.style.left = (e.clientX + offset[0]) + 'px';
wanBox.style.top = (e.clientY + offset[1]) + 'px';
}
});
document.addEventListener('mouseup', function () {
move = false;
});
for (let i = 0; i < timeOut.length; i++) {
timeOut[i].addEventListener("change", function () {
timeStatus = this.getAttribute("data-name");
})
}
let cont = localStorage.getItem("t");
if (!cont) {
ShowAlertDialog('注意', '按下“Ctrl+Alt+A”键即可呼出Steam大屏Plus菜单', "明白!");
localStorage.setItem("t", "t")
}
//=============================游戏详情页&csgo市场=======================//
let appId = steamURL.match(/app\/(\d+)/);
let community = /https:\/\/steamcommunity.com\/market\/listings\/730/.test(steamURL)
let headerStandard = document.querySelector(".apphub_HeaderStandardTop")
let communityName = document.getElementById("largeiteminfo_item_name")
let main = document.getElementById("BG_bottom")
let tableMain = document.querySelector(".market_commodity_order_block") || document.getElementById("largeiteminfo_warning")
let csgoName = ""
let csgoId
/**
* 传入csgo磨损度返回对应的词语
* @param {Float} num -武器磨损度
* @return {String<崭新出厂|略有磨损|久经沙场|破损不堪|战痕累累|"">}
* */
function csgoAbrasion(num) {
if (0 <= num && num < 0.07) return "崭新出厂";
else if (0.07 <= num && num < 0.15) return "略有磨损";
else if (0.15 <= num && num < 0.37) return "久经沙场";
else if (0.37 <= num && num < 0.44) return "破损不堪";
else if (0.44 <= num && num <= 1) return "战痕累累";
else return "";
}
/**
* 消息提示
* @param {NodeList} dom -显示消息的容器
* @param {String<Selection>} node -消息内容
* @param {String<JSON>} [options] -额外配置
* */
function showMsg(dom, node, options) {
let container = document.querySelectorAll(dom)
for (let i = 0; i < container.length; i++) {
if (document.querySelectorAll(dom)[i].dataset.msg) {
container[i].innerHTML = document.querySelectorAll(dom)[i].dataset.msg
continue
}
container[i].innerHTML = node
}
}
/**
* 数字单位转换为万
* @param {Number} number -要转换的数字
* @param {Number} [decimals=2] -要省略的位数
* */
function numberPro(number, decimals = 2) {
if (typeof number !== 'number' || isNaN(number)) {
throw new Error('提供的号码无效');
}
const tenThousand = 10000;
if (number >= tenThousand) {
const formattedNumber = (number / tenThousand).toFixed(decimals);
// 如果没有小数部分,则去掉小数点和后面的0
return parseFloat(formattedNumber) % 1 === 0 ? parseInt(formattedNumber, 10) + '万' : formattedNumber + '万';
} else {
return number.toString();
}
}
if (appId && headerStandard) {
// 跳转启发来自 https://www.xiaoheihe.cn/app/bbs/link/144510651
headerStandard.insertAdjacentHTML("afterbegin", `<div class="apphub_OtherSiteInfo" style="margin-left: 10px" title="跳转到小黑盒"><a class="btnv6_blue_hoverfade btn_medium" href="https://www.xiaoheihe.cn/app/topic/game/pc/${appId[1]}"><img style="width: 29px;height: 29px;" src="https://imgheybox.max-c.com/oa/2024/11/27/3912834da32296bd985281f8944e75fc.ico" alt="小黑盒"></a></div>`)
headerStandard.insertAdjacentHTML("afterbegin", `<div class="apphub_OtherSiteInfo" style="margin-left: 10px" title="跳转到SteamDB"><a class="btnv6_blue_hoverfade btn_medium" href="https://steamdb.info/app/${appId[1]}"><img style="width: 29px;height: 29px;" src="https://steamdb.info/static/logos/vector_prefers_schema.svg" alt="SteamDB"></a></div>`)
let userPlay = document.querySelector(".glance_ctn_responsive_left")
userPlay.insertAdjacentHTML("afterbegin", `<div class="dev_row" style="margin-top: 10px"><div class="subtitle column">在线人数:</div><div class="summary column" id="user-num" style="color: #8f98a0">查询中...</div></div><div class="dev_row"><div class="subtitle column">今日峰值:</div><div class="summary column user-num-max" style="color: #8f98a0">查询中...</div></div><div class="dev_row"><div class="subtitle column">历史峰值:</div><div class="summary column user-num-max" style="color: #8f98a0">查询中...</div></div><div class="dev_row"><div class="subtitle column">平均游戏时间:</div><div class="summary column user-num-max-hey" style="color: #8f98a0">查询中...</div></div>`)
let userPlayDom = document.querySelectorAll(".user-num-max")
// 当前游戏在线人数
GM_xmlhttpRequest({
method: "GET",
url: `https://api.steampowered.com/ISteamUserStats/GetNumberOfCurrentPlayers/v1/?appid=${appId[1]}`,
onload: function (res) {
let data = JSON.parse(res.response)
let msg = document.getElementById("user-num")
if (data.response.result !== 1) {
showMsg("#user-num", "查询结果异常")
return;
}
msg.innerText = numberPro(data.response.player_count) || "查询结果异常"
},
onerror: function (error) {
throw new Error(error)
showMsg("#user-num", "查询结果错误")
}
});
GM_xmlhttpRequest({
method: "GET",
url: `https://steamcharts.com/app/${appId[1]}`,
onload: function (res) {
let userPlayArr
try {
let data = res.responseText
userPlayArr = data.match(/(?<="num">)(\d+)/g)
userPlayDom[0].textContent = numberPro(+userPlayArr[1])
userPlayDom[1].textContent = numberPro(+userPlayArr[2])
} catch (e) {
showMsg(".user-num-max", "查询失败")
throw new Error(e)
}
},
onerror: function (error) {
throw new Error(error)
showMsg(".user-num-max", "查询失败")
}
});
GM_xmlhttpRequest({
method: "GET",
url: `https://www.xiaoheihe.cn/app/topic/game/pc/${appId[1]}`,
onload: function (res) {
let heyMsg = document.querySelector(".user-num-max-hey")
try {
let data = JSON.parse(res.responseXML.getElementById("__NUXT_DATA__").innerText);
for (let i = 0; i < data.length; i++) {
if (data[i] === "平均游戏时间") {
heyMsg.textContent = `${data[i + 1]} 数据来源:小黑盒`
}
}
} catch (e) {
showMsg(".user-num-max-hey","查询失败")
throw new Error(e)
}
},
onerror: function (error) {
throw new Error(error)
}
});
} else if (community && communityName) {
// 延时加载 等待元素加载完成
setTimeout(function () {
main.insertAdjacentHTML("beforeend", `<h2 class="market_section_title">网易BUFF</h2><span id="BUFF-total"></span><div id="searchResultsRows" style=""><div class="market_listing_table_header"><div class="market_listing_price_listings_block"><span class="market_listing_right_cell market_listing_action_buttons">跳转到BUFF</span><span class="market_listing_right_cell market_listing_their_price" style="text-align: center">价格</span><span class="market_listing_right_cell market_listing_their_price" style="width: 220px;text-align: center">磨损度</span></div><div><span class="market_listing_header_namespacer"></span>名称</div></div><div id="BUFF-body"></div><div id="content_loading" class="page_content_ctn dark" style="display: block;"><div class="home_page_content more_content" id="BUFF-loading"><div class="LoadingWrapper"><div class="LoadingThrobber"><div class="Bar Bar1"></div><div class="Bar Bar2"></div><div class="Bar Bar3"></div></div><div class="BUFF-msg LoadingText">正在加载更多内容…</div></div></div></div></div><div id="BUFF-up">⬆️</div>`)
tableMain.insertAdjacentHTML("afterbegin", `<div class="market_commodity_orders_table_container"><table class="market_commodity_orders_table"><tbody id="BUFF-table"><tr><th align="right">编号</th><th align="right">Steam价格</th><th align="right">Buff价格</th><th align="right">利润</th><th align="right">折扣率</th></tr><tr class="BUFF-msg" id="BUFF-tablet-msg"><th colspan="5">查询中...</th></tr></tbody></table></div>`)
let BUFFcontent = document.getElementById("BUFF-body")
let BUFFtitle = document.getElementById("BUFF-title")
let BUFFtable = document.getElementById("BUFF-table")
let BUFFloading = document.getElementById("BUFF-loading")
let BUFFtotal = document.getElementById("BUFF-total")
let steamPrice = document.querySelector(".market_listing_price.market_listing_price_with_fee:not(.price-Buff)")
let appearance = document.getElementById("largeiteminfo_item_descriptors").firstElementChild.textContent.match(/崭新出厂|略有磨损|久经沙场|破损不堪|战痕累累/)
let pageNum = 1
let initNum = 1
let sliderObserver
csgoName = communityName.innerText
if (appearance) csgoName += appearance[0]
BUFFtable.addEventListener("click", (e) => {
if (!e.target.dataset.index) return;
let index = e.target.dataset.index
let list = document.querySelectorAll("#BUFF-body .market_listing_row.market_recent_listing_row")[index]
list.classList.add("BUFF-active")
list.scrollIntoView({behavior: 'smooth', block: 'center'});
let time = setTimeout(() => {
list.classList.remove("BUFF-active")
}, 5500)
})
document.documentElement.style.setProperty("--csgoColor", communityName.style.color)
communityName.insertAdjacentHTML("beforebegin", `<a href="https://buff.163.com/market/csgo#game=csgo&page_num=1&search=${csgoName}" id="BUFF-URL"><img style="width: 40px;height: 40px;float: right;" title="跳转到BUFF" src="https://g.fp.ps.netease.com/market/file/59b156975e6027bce06e8f6ceTyFGdsj"></a>`)
// 调用Buff查询接口查询商品ID
GM_xmlhttpRequest({
method: "GET",
url: `https://buff.163.com/api/market/goods?game=csgo&page_num=1&search=${csgoName}&use_suggestion=0&_=1738903063922`,
onload: function (response) {
let data = JSON.parse(response.response)
console.log(data)
if (data.code !== "OK") {
showMsg(".BUFF-msg", `请求ID异常,异常信息:${data.error} 状态码:${data.code}`, data)
return
} else if (data.data.items.length === 0) {
showMsg(".BUFF-msg", `未查询到该商品`)
return;
}
// 创建观察器
sliderObserver = new IntersectionObserver((entries) => {
let data = entries[0]
if (!data.isIntersecting) return
if (!csgoId) return
getBUFFList()
})
sliderObserver.observe(BUFFloading)
if (data.data.items.length === 1 && data.data.items[0].id) {
csgoId = data.data.items[0].id
} else if (data.data.items.length > 1) {
let dom = ""
for (let i = 0; i < data.data.items.length; i++) {
let index = data.data.items[i]
if (communityName.innerText === data.data.items[i].short_name) {
csgoId = data.data.items[i].id
break;
} else if (i === data.data.items.length - 1) {
showMsg("#BUFF-tablet-msg", `<th colspan="5">价格异常</th>`)
dom += `<div class="market_listing_row market_recent_listing_row"><div class="market_listing_item_img_container"><img src="${index?.img_src || index.goods_info.icon_url}" onerror="this.src=document.querySelector('.market_listing_largeimage img').src" style="border-color: var(--csgoColor);" class="market_listing_item_img economy_item_hoverable" alt=""></div><div class="market_listing_price_listings_block"><div class="market_listing_right_cell market_listing_action_buttons"><div class="market_listing_buy_button"><a href="https://buff.163.com/goods/${index.id}"class="item_market_action_button btn_green_white_innerfade btn_small"><span>跳转到BUFF</span></a></div></div><div class="market_listing_right_cell market_listing_their_price"><span class="market_table_value"><span class="market_listing_price market_listing_price_with_fee price-Buff ">¥ ${index.price || index.sell_reference_price}</span><br></span></div><div class="market_listing_right_cell" style="width: 220px;"><div class="market_listing_row_action" style="margin: 0">磨损度:${index.asset_info?.paintwear || "暂无"}<div class="wear-pointer"><div class="wear-pointer-icon" style="left: ${+index.asset_info?.paintwear * 100 || "0"}%"></div></div><div class="progress" style="margin-bottom: 5px;"><div class="progress-bar progress-bar-fn" style="width: 7%;" title="崭新出厂"></div><div class="progress-bar progress-bar-success" style="width: 8%;" title="略有磨损"></div><div class="progress-bar progress-bar-warning" style="width: 23%;" title="久经沙场"></div><div class="progress-bar progress-bar-danger" style="width: 7%;" title="破损不堪"></div><div class="progress-bar progress-bar-bs" style="width: 55%;" title="战痕累累"></div></div></div></div></div><div class="market_listing_item_name_block"><span class="market_listing_item_name economy_item_hoverable" style="color: var(--csgoColor);">${index.name}</span><br><div class="market_listing_row_details economy_item_hoverable"><br><div class="sticker_info sticker_infoBUFF" style="width:100px; margin:4px; padding:8px;">${index.sell_num}件在售</div></div></div></div>`
BUFFcontent.insertAdjacentHTML("beforeend", dom)
sliderObserver.unobserve(BUFFloading)
BUFFloading.remove()
return;
}
dom += `<div class="market_listing_row market_recent_listing_row"><div class="market_listing_item_img_container"><img src="${index?.img_src || index.goods_info.icon_url}" onerror="this.src=document.querySelector('.market_listing_largeimage img').src" style="border-color: var(--csgoColor);" class="market_listing_item_img economy_item_hoverable" alt=""></div><div class="market_listing_price_listings_block"><div class="market_listing_right_cell market_listing_action_buttons"><div class="market_listing_buy_button"><a href="https://buff.163.com/goods/${index.id}"class="item_market_action_button btn_green_white_innerfade btn_small"><span>跳转到BUFF</span></a></div></div><div class="market_listing_right_cell market_listing_their_price"><span class="market_table_value"><span class="market_listing_price market_listing_price_with_fee price-Buff ">¥ ${index.price || index.sell_reference_price}</span><br></span></div><div class="market_listing_right_cell" style="width: 220px;"><div class="market_listing_row_action" style="margin: 0">磨损度:${index.asset_info?.paintwear || "暂无"}<div class="wear-pointer"><div class="wear-pointer-icon" style="left: ${+index.asset_info?.paintwear * 100 || "0"}%"></div></div><div class="progress" style="margin-bottom: 5px;"><div class="progress-bar progress-bar-fn" style="width: 7%;" title="崭新出厂"></div><div class="progress-bar progress-bar-success" style="width: 8%;" title="略有磨损"></div><div class="progress-bar progress-bar-warning" style="width: 23%;" title="久经沙场"></div><div class="progress-bar progress-bar-danger" style="width: 7%;" title="破损不堪"></div><div class="progress-bar progress-bar-bs" style="width: 55%;" title="战痕累累"></div></div></div></div></div><div class="market_listing_item_name_block"><span class="market_listing_item_name economy_item_hoverable" style="color: var(--csgoColor);">${index.name}</span><br><div class="market_listing_row_details economy_item_hoverable"><br><div class="sticker_info sticker_infoBUFF" style="width:100px; margin:4px; padding:8px;">${index.sell_num}件在售</div></div></div></div>`
}
}
steamPrice = steamPrice ? +steamPrice.innerText.replace(/[^\d.]/g, "") : +data.data?.goods_infos?.csgoId?.steam_price_cny || document.querySelectorAll(".market_commodity_orders_header_promote")[1]?.textContent.replace(/[^\d.]/g, "") || 0
// 拿到ID发送商品列表请求
getBUFFList()
},
onerror(response) {
throw new Error(response)
showMsg(".BUFF-msg", `查询ID数据错误 请查看控制台`)
}
});
function getBUFFList() {
GM_xmlhttpRequest({
method: "GET",
url: `https://buff.163.com/api/market/goods/sell_order?game=csgo&goods_id=${csgoId}&page_num=${pageNum}&mode=&allow_tradable_cooldown=1`,
onload: function (response) {
let data = JSON.parse(response.response)
console.log(data)
if (data.code !== "OK") {
showMsg(".BUFF-msg", `请求列表异常,异常信息:${data.error} 状态码:${data.code}`, data)
sliderObserver.unobserve(BUFFloading)
return
} else if (pageNum * 10 >= data.data.total_count) {
showMsg(".LoadingText", `没有更多数据了`)
sliderObserver.unobserve(BUFFloading)
} else if (data.data.items.length === 0) {
showMsg(".BUFF-msg", `未查询到该商品`)
sliderObserver.unobserve(BUFFloading)
return
}
document.getElementById("BUFF-tablet-msg").style.display = 'none'
BUFFtotal.innerText = `总数:${data.data.total_count}`
let sticker
for (let i = 0; i < data.data.items.length; i++) {
let index = data.data.items[i]
BUFFcontent.insertAdjacentHTML("beforeend", `<div class="market_listing_row market_recent_listing_row"><div class="market_listing_item_img_container"><img src="${index.img_src}" style="border-color: var(--csgoColor); background: url('${data.data.src_url_background}');background-size: 100% 100%" class="market_listing_item_img economy_item_hoverable" alt=""></div><div class="market_listing_price_listings_block"><div class="market_listing_right_cell market_listing_action_buttons"><div class="market_listing_buy_button"><a data-appid="${index.asset_info?.appid}" data-assetid="${index.asset_info?.assetid}" data-sell_order_id="${index.id}" data-classid="${index.asset_info?.classid}" data-contextid="${index.asset_info?.contextid}" data-instanceid="${index.asset_info?.instanceid}" class="getBUFF item_market_action_button btn_green_white_innerfade btn_small"><span>跳转到BUFF</span></a></div></div><div class="market_listing_right_cell market_listing_their_price"><span class="market_table_value"><span class="market_listing_price market_listing_price_with_fee price-Buff">¥ ${index.price}</span><br></span></div><div class="market_listing_right_cell" style="width: 220px;"><div class="market_listing_row_action" style="margin: 0">磨损度:${index.asset_info?.paintwear || "暂无"}<div class="wear-pointer"><div class="wear-pointer-icon" style="left: ${+index.asset_info?.paintwear * 100 || "0"}%"></div></div><div class="progress" style="margin-bottom: 5px;"><div class="progress-bar progress-bar-fn" style="width: 7%;" title="崭新出厂"></div><div class="progress-bar progress-bar-success" style="width: 8%;" title="略有磨损"></div><div class="progress-bar progress-bar-warning" style="width: 23%;" title="久经沙场"></div><div class="progress-bar progress-bar-danger" style="width: 7%;" title="破损不堪"></div><div class="progress-bar progress-bar-bs" style="width: 55%;" title="战痕累累"></div></div></div></div></div><div class="market_listing_item_name_block"><span class="market_listing_item_name economy_item_hoverable" style="color: var(--csgoColor);">${data.data.goods_infos[csgoId].short_name}(${csgoAbrasion(+index.asset_info?.paintwear)})</span><div style="line-height: 35px;">${index.asset_info.info?.fraudwarnings ? "❗" + index.asset_info.info.fraudwarnings : ""}</div><div class="market_listing_row_details economy_item_hoverable"><div class="sticker_info sticker_infoBUFF" style="width:100px; margin:4px; padding:8px;"></div></div></div></div>`)
BUFFtable.insertAdjacentHTML("beforeend", `<tr><td align="right" class=""><a href="javascript:" data-index="${initNum - 1}">${initNum}</a></td><td align="right">${steamPrice}</td><td align="right">${index.price}</td><td align="right">${(steamPrice - index.price).toFixed(2)}</td><td>${((1 - index.price / steamPrice) * 100).toFixed(2) + "%"}</td></tr>`)
if (index.asset_info.info?.stickers.length !== 0) {
sticker = document.querySelectorAll(".sticker_infoBUFF")[initNum - 1]
for (let j = 0; j < index.asset_info.info.stickers.length; j++) {
sticker.insertAdjacentHTML("beforeend", `<div class="sticker"><div class="sticker-2"><a href="https://buff.163.com/market/csgo#game=csgo&page_num=1&search=印花 | ${index.asset_info.info.stickers[j].name}&tab=selling">${index.asset_info.info.stickers[j].name}</a><div>价格:${index.asset_info.info.stickers[j]?.sell_reference_price ? "¥" + index.asset_info.info.stickers[j].sell_reference_price : "暂无价格"}</div><div>磨损度:${index.asset_info.info.stickers[j]?.wear ? ((1 - +index.asset_info.info.stickers[j].wear) * 100).toFixed(2) + "%" : "完美无缺"}</div></div><img width="64" height="48" src="${index.asset_info.info.stickers[j].img_url}"></div>`)
}
}
if (index.asset_info.info?.keychains.length !== 0) {
for (let j = 0; j < index.asset_info.info.keychains.length; j++) {
sticker.insertAdjacentHTML("beforeend", `<div class="sticker"><div class="sticker-2" style="transform: translateY(50%);left: 85%;"><a href="https://buff.163.com/market/csgo#game=csgo&page_num=1&search=挂件 | ${index.asset_info.info.keychains[j].name}&tab=selling">挂件 | ${index.asset_info.info.keychains[j].name}</a><div>挂件价格:${index.asset_info.info.keychains[j]?.sell_reference_price ? "¥" + index.asset_info.info.keychains[j].sell_reference_price : "暂无价格"}</div><div>挂件模板:${index.asset_info.info?.keychains[j].pattern || "暂无模板"}</div><div style="color: ${index.asset_info.info.keychains[j]?.pattern_color || "rgb(150, 150, 150)"}">挂件颜色:${index.asset_info.info.keychains[j]?.pattern_color || "暂无颜色"}</div></div><img width="64" height="48" src="${index.asset_info.info.keychains[j].img_url}"></div>`)
}
}
initNum++
}
let getBuff = document.querySelectorAll(".getBUFF")
for (let i = 0; i < getBuff.length; i++) {
getBuff[i].addEventListener("click", function () {
let BuffData = {}
BuffData.appid = this.dataset.appid
BuffData.assetid = this.dataset.assetid
BuffData.classid = this.dataset.classid
BuffData.contextid = this.dataset.contextid
BuffData.instanceid = this.dataset.instanceid
BuffData.sell_order_id = this.dataset.sell_order_id
let code = this.firstElementChild
code.textContent = "正在跳转"
location.href = `https://buff.163.com/goods/${csgoId}?appid=730&classid=${BuffData.classid}&instanceid=${BuffData.instanceid}&assetid=${BuffData.assetid}&contextid=${BuffData.contextid}&sell_order_id=${BuffData.sell_order_id}`
})
}
pageNum++
},
onerror(response) {
throw new Error(response)
showMsg(".BUFF-msg", `列表数据错误 请查看控制台`)
sliderObserver.unobserve(BUFFloading)
}
})
}
}, 500)
}
})();