steam show Community Items beta

add Community Items images

当前为 2023-03-20 提交的版本,查看 最新版本

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

You will need to install an extension such as Tampermonkey to install this script.

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         steam show Community Items beta
// @description  add Community Items images
// @namespace    steam_Items_images
// @author       Covenant
// @version      1.0.3
// @license      MIT
// @homepage
// @match        https://store.steampowered.com/*
// @match        https://steamcommunity.com/*
// @match        https://steamdb.info/*
// @match        https://www.steamcardexchange.net/*
// @icon         
// @grant        GM_setValue
// @grant        GM_getValue
// @grant        GM_registerMenuCommand
// @grant        GM_xmlhttpRequest
// @connect      www.steamcardexchange.net
// @connect      steamcommunity.com
// @run-at       document-end
// @noframes
// ==/UserScript==
var timeoutID;
var is_Community_Items_Exist=true;
var is_avatar_Exist=true;
var ary_lang_steam=["english","japanese","latam","bulgarian","schinese","tchinese","czech","danish","dutch","finnish","french","german","greek","hungarian","italian","koreana","norwegian","polish","brazilian","portuguese","romanian","russian","spanish","swedish","thai","turkish","ukrainian","vietnamese"];
var akamaihd="steamcdn-a.akamaihd.net";
var steamstatic="cdn.cloudflare.steamstatic.com";
var steamcommunity="steamcommunity.com";
var profilebackground="/economy/profilebackground";
var public_images="/steamcommunity/public/images";
var url_steam_app;
var url_category_753_Game;
var url_avatar;
var url_points_shop;
var url_curatorsreviewing;
var url_cardexchange;
var url_steamdb_app;
var url_steamdb_communityitems;
var url_steamdb_achievements;
function create_style(innerText,class_name){
    var style=document.createElement("style");
    if(Array.isArray(class_name)){
        for(let i=0; i<class_name.length; i++){style.classList.add(class_name[i]);}
    }
    else if(typeof class_name==='string'){style.classList.add(class_name);}
    style.textContent=innerText;
    style.title="user_gm_css";
    document.body.appendChild(style);
    return style;
}
var style_font_face=create_style("@font-face{font-family: 'color_emoji';src: local('Segoe UI Emoji'),local('Noto Color Emoji');}\n",["user_gm_css","css_steam_Items_images"]);
var font_family_steam_main="font-family: 'Motiva Sans','color_emoji','Noto Sans CJK JP','Meiryo','Yu Gothic','Microsoft JhengHei','old_emoji',sans-serif;";
var font_family_steam_info="font-family: Arial, Helvetica,'color_emoji','Noto Sans CJK JP','Meiryo','Yu Gothic','Microsoft JhengHei','old_emoji',sans-serif;";
var style=create_style(".user_div_steam_main{"+font_family_steam_main+"font-weight: 100;}\n",["user_gm_css","css_steam_Items_images"]);
style.textContent+=".user_div_steam_info{"+font_family_steam_info+"font-weight: 100;}\n";
style.textContent+=".user_newmodal_background{position: fixed;z-index: 900;background: #000000;opacity: 0.8;top: 0;right: 0;bottom: 0;left: 0;}\n";
function create_div(class_name,is_appendChild,node,refNode){
    var div=document.createElement("div");
    if(Array.isArray(class_name)){
        for(let i=0; i<class_name.length; i++){div.classList.add(class_name[i]);}
    }
    else if(typeof class_name==='string'){div.classList.add(class_name);}
    div.style.backgroundSize='contain';
    div.style.backgroundRepeat='no-repeat';
    div.lang='ja';
    if(is_appendChild){
        node.appendChild(div);
    }
    else{node.insertBefore(div, refNode);}
    return div;
}
var newmodal_background=create_div("user_newmodal_background",true,document.body);
newmodal_background.style.setProperty('display','none');
function create_a(text,url,class_name,is_appendChild,node,refNode){
    var anchor=document.createElement("a");
    anchor.href=url;
    anchor.innerText=text;
    anchor.title=text;
    if(Array.isArray(class_name)){
        for(let i=0; i<class_name.length; i++){anchor.classList.add(class_name[i]);}
    }
    else if(typeof class_name==='string'){anchor.classList.add(class_name);}
    anchor.target="_blank";
    if(is_appendChild){
        node.appendChild(anchor);
    }
    else{node.insertBefore(anchor, refNode);}
    return anchor;
}
function create_img_click(url,title,class_name,is_appendChild,node,refNode){
    let img = document.createElement('img');
    img.src=url;
    img.title=title;
    img.alt=title;
    img.width=54;
    img.style.setProperty('z-index','1000');
    img.addEventListener('click',() => {
        if(img.style.getPropertyValue('position')!="fixed"){
            img.style.setProperty('position','fixed');
            img.style.setProperty('left',"50%");
            img.style.setProperty('top',"50%");
            img.style.setProperty('transform',"translate(-50%,-50%)");
            img.style.setProperty('max-height',"95%");
            img.removeAttribute('width');
            newmodal_background.style.removeProperty('display');
        }
        else{
            img.style.removeProperty('position');
            img.style.removeProperty('left');
            img.style.removeProperty('top');
            img.style.removeProperty('transform');
            img.setAttribute('width', '54');
            newmodal_background.style.setProperty('display','none');
        }
    });
    if(is_appendChild){
        node.appendChild(img);
    }
    else{node.insertBefore(img, refNode);}
    return img;
}
function create_span(text,class_name,is_appendChild,node,refNode){
    var span=document.createElement("span");
    span.innerText=text;
    if(Array.isArray(class_name)){
        for(let i=0; i<class_name.length; i++){span.classList.add(class_name[i]);}
    }
    else if(typeof class_name==='string'){span.classList.add(class_name);}
    if(is_appendChild){
        node.appendChild(span);
    }
    else{node.insertBefore(span, refNode);}
    return span;
}
function create_br(is_appendChild,node,refNode){
    var br = document.createElement("br");
    if(is_appendChild){
        node.appendChild(br);
    }
    else{node.insertBefore(br, refNode);}
    return br;
}
function fn_gm_XMLHttpRequest(url,fn){
    GM_xmlhttpRequest({
        method: "GET",
        url: url,
        headers:{
            'content-type': 'text/html; charset=UTF-8',
            'user-agent':window.navigator.userAgent
        },
        onload: function (response){
            fn(response);
            /*console.log([
                "GM_xmlhttpRequest",
                response.status,
                response.statusText,
                response.readyState,
                response.responseHeaders,
                //response.responseText,
                response.finalUrl].join("\n")
            );//*/
        }
    });
}
function fn_url(url){
    var str_url=new URL(url);
    var params=new URLSearchParams(str_url.search);
    return [str_url,params];
}
//console.log("break");
function steam_app_id(url){
    url=fn_url(url);
    var host=url[0].host;
    var pathname=url[0].pathname;
    var ary_pathname=pathname.split('/');
    if(url[0].host=="store.steampowered.com"){
        if(ary_pathname[1]=="app")return ary_pathname[2];
        else if(ary_pathname[1]=="api")return url[1].get('appids');
    }
    else if(url[0].host=="steamdb.info"){
        if(ary_pathname[1]=="app")return ary_pathname[2];
    }
    else if(url[0].host=="steamcommunity.com"){
        if(ary_pathname[1]=="app")return ary_pathname[2];
        if(ary_pathname[3]=="achievements"){//achievements
            if(!isNaN(ary_pathname[2])){return ary_pathname[2];}
            else{
                var gameLogo_a=document.querySelectorAll('div.gameLogo>a')[0];
                if(gameLogo_a!=undefined){return fn_url(gameLogo_a.href)[0].pathname.split('/')[2];}
                else{return null;}
            }
        }
        if(url[1].get('category_753_Game[]')!=null)return url[1].get('category_753_Game[]').replace(/tag_app_/i, '');//Community Market
        if(ary_pathname[3]=="753")return parseInt(ary_pathname[4],10);//Community Market item
        if(ary_pathname[3]=="gamecards")return parseInt(ary_pathname[4],10);//badge
    }
    else if(url[0].host=="www.steamcardexchange.net"){
        if(url[0].search.search(new RegExp("\\?gamepage-appid-", "i"))==0){
            return url[0].search.replace(/[^0-9.]/g, '').replace(/(\\..*?)\\..*/g, '$1');
        }
    }
    return null;
}
function fn_re_market_check(response){
    let dom=document.createRange().createContextualFragment(response.responseText);
    if(response.status==200){
        if(dom.querySelectorAll('div.market_sortable_column').length==0)is_Community_Items_Exist=false;
        var anchor=document.querySelectorAll('a.anchor_Items');
        for(let i = 0; i < anchor.length; i++){
            if(is_Community_Items_Exist){
                anchor[i].parentNode.classList.add('link_item');
            }
            else{anchor[i].style.display="none";}
        }
        anchor[0].parentNode.classList.add('checked_item');
    }
    else{//451
        console.log("market response.status: "+response.status+response.responseHeaders);
    }
}
function fn_re_avatar_check(response){
    if(response.status==200){
        if(response.finalUrl.search(new RegExp("/Avatar/List", "i"))==-1)is_avatar_Exist=false;
        var anchor=document.querySelectorAll('a.anchor_avatar')[0];
        if(is_avatar_Exist){
            anchor.parentNode.classList.add('link_avatar');
        }
        else{anchor.style.display="none";}
        anchor.parentNode.classList.add('checked_avatar');
    }
    else{//
        console.log("avatar response.status: "+response.status+response.responseHeaders);
    }
}
function fn_re_item(response){
    let dom=document.createRange().createContextualFragment(response.responseText);
    var url=fn_url(response.finalUrl);
    var appid=url[0].search.replace(/\?gamepage-appid-/i, '');
    if(response.status==200){
        var output=document.querySelectorAll('div.user_item')[0];
        var badge=Array.from(dom.querySelectorAll('div.badge>div>img'));//badge
        for(let j=0; j<badge.length; j++){
            create_img_click(badge[j].src.replace(akamaihd, steamstatic),'badge','',true,output);
        }
        create_br(true,output);
        var ary_img=Array.from(dom.querySelectorAll('div.emoticon>div>img'));//emoticon
        ary_img=ary_img.concat(Array.from(dom.querySelectorAll('div.background>div>a>img')));
        for(let j=0; j<ary_img.length; j++){
            if(ary_img[j].src.search(new RegExp("/economy/emoticon", "i"))==-1){
                let img_url=ary_img[j].src.replace(akamaihd, steamstatic);
                img_url=img_url.replace(steamcommunity, steamstatic);
                img_url=img_url.replace(profilebackground, public_images);
                create_img_click(img_url,'','',true,output);
            }
        }
        create_br(true,output);
        var ary_animated=Array.from(dom.querySelectorAll('div.avataranimated>div>img.image-animated'));//animated
        ary_animated=ary_animated.concat(Array.from(dom.querySelectorAll('div.sticker>div>img.image-animated')),Array.from(dom.querySelectorAll('div.animated>div>a>img')));
        ary_animated=ary_animated.concat(Array.from(dom.querySelectorAll('div.minibg>div>img')),Array.from(dom.querySelectorAll('div.aframe>div>img.image-animated')));
        for(let j=0; j<ary_animated.length; j++){
            if(true){
                create_img_click(ary_animated[j].src.replace(akamaihd, steamstatic),'','',true,output);
            }
        }
        var href=dom.querySelectorAll('div.booster>div>div>a')[0].href;
        var card=dom.querySelectorAll('div.card>div>a>img');
        create_a("booster "+6000/(card.length/2),href,"linkbar",true,output);
        console.log("fn_re_item 200");
    }
    else{//
        console.log("response.status: "+response.status+response.responseHeaders);
    }
}
function fn_re_avatar(response){
    let dom=document.createRange().createContextualFragment(response.responseText);
    var url=fn_url(response.finalUrl);
    if(response.status==200){
        var output=document.querySelectorAll('div.user_item')[0];//console.log(response.responseText);
        var avatarBlockFull=Array.from(dom.querySelectorAll('div#avatarBlockFull>a>img'));
        for(let j=0; j<avatarBlockFull.length; j++){
            let img_url=avatarBlockFull[j].src;
            create_img_click(img_url,'','',true,output);
        }
        create_br(true,output);
        console.log("fn_re_avatar 200");
    }
    else{//
        console.log("response.status: "+response.status+response.responseHeaders);
    }
}
function main_01(game_meta_data,appid){
    var tmp=document.querySelectorAll('div.Community_Items')[0];//old script
    if(tmp==undefined){
        var category_block=document.querySelectorAll('div#category_block')[0];
        var div_item_link=create_div(['block',"user_div_steam_info","Community_Items"],false,game_meta_data[0],category_block);
        var a_avatar=create_a("Avatar",url_avatar,['linkbar',"anchor_avatar"],true,div_item_link);
        var a_market=create_a("Community Market",url_category_753_Game,['linkbar',"anchor_Items"],true,div_item_link);
        var a_points=create_a("Points Shop",url_points_shop,['linkbar',"anchor_Items"],true,div_item_link);
        var a_steamcardexchange=create_a("steamcardexchange",url_cardexchange,['linkbar',"anchor_Items"],true,div_item_link);
        var a_steamdb=create_a("steamdb/communityitems",url_steamdb_communityitems,['linkbar',"anchor_Items"],true,div_item_link);
        div_item_link.style.backgroundImage="url('https://cdn.cloudflare.steamstatic.com/steam/apps/"+appid+"/page_bg_generated_v6b.jpg')";
        div_item_link.classList.add('link_dev');
        fn_gm_XMLHttpRequest(url_category_753_Game,fn_re_market_check);
        fn_gm_XMLHttpRequest(url_avatar,fn_re_avatar_check);
    }
}
function main_02(appid){
    var div_Community_item=document.querySelectorAll('div.Community_Items')[0];
    if(div_Community_item.classList.contains('checked_item')&&div_Community_item.classList.contains('checked_avatar')){
        window.clearInterval(timeoutID);
        if(div_Community_item.classList.contains('link_item'))fn_gm_XMLHttpRequest(url_cardexchange,fn_re_item);
        if(div_Community_item.classList.contains('link_avatar'))fn_gm_XMLHttpRequest("https://steamcommunity.com/ogg/"+appid+"/Avatar/List",fn_re_avatar);//page dont load
    }
}
function fn_steam_url(appid){
    url_steam_app="https://store.steampowered.com/app/"+appid;
    url_category_753_Game="https://steamcommunity.com/market/search?appid=753&category_753_Game[]=tag_app_"+appid+"#p1_name_asc";
    url_avatar="https://steamcommunity.com/ogg/"+appid+"/Avatar/List";
    url_points_shop="https://store.steampowered.com/points/shop/app/"+appid;
    url_curatorsreviewing="https://store.steampowered.com/curators/curatorsreviewing/?appid="+appid;
    url_cardexchange="https://www.steamcardexchange.net/index.php?gamepage-appid-"+appid;
    url_steamdb_app="https://steamdb.info/app/"+appid+"/";
    url_steamdb_communityitems="https://steamdb.info/app/"+appid+"/communityitems/";
    url_steamdb_achievements="https://steamdb.info/app/"+appid+"/stats/";
}
(function(){//main
    'use strict';
    let url=fn_url(document.location);
    let appid=steam_app_id(document.location);//document.location.host+document.location.pathname+document.location.search+document.location.hash
    fn_steam_url(appid);
    let lang=document.documentElement.lang;
    console.log("steam: "+appid);
    if(url[0].host=="store.steampowered.com"){
        var game_meta_data=document.querySelectorAll('div.game_meta_data');//steam game page
        if(game_meta_data.length>0){
            window.setTimeout(( () => main_01(game_meta_data,appid) ), 100);//old script
            var div_item=create_div(['block',"user_div_steam_info","user_item"],true,game_meta_data[0]);
            timeoutID = window.setInterval(( () => main_02(appid)), 1000);//show item image
            var div_curators=create_div(['block',"user_div_steam_info","user_curators"],true,game_meta_data[0]);
            create_a("curators",url_curatorsreviewing,"linkbar",true,div_curators);
        }
        if(url[0].pathname=="/curators/curatorsreviewing/"){//steam curatorsreviewing page
            var page_content=document.querySelectorAll('div.light_container>div.page_content');
            var div_lang=create_div(["breadcrumbs","user_div_steam_main"],false,page_content[0],page_content[0].firstChild);
            for(let i=0; i<ary_lang_steam.length; i++){
                let anchor_lang=create_a(ary_lang_steam[i],"#","lang",true,div_lang);
                anchor_lang.setAttribute("onclick","ChangeLanguage('"+ary_lang_steam[i]+"'); return false;");
                create_span(" / ","breadcrumb_separator",true,div_lang);
            }
        }
    }
    else if(url[0].host=="steamcommunity.com"){
        var div_1=document.querySelectorAll('div.market_search_results_header>div')[0];//
        if(div_1!=undefined){
            create_a(appid,url_steam_app,"market_searchedForTerm",true,div_1);
            create_a("steamdb",url_steamdb_communityitems,"market_searchedForTerm",true,div_1);
            create_a("steamcardexchange",url_cardexchange,"market_searchedForTerm",true,div_1);
        }
        var div_2=document.querySelectorAll('div.market_listing_nav')[0];//
        if(div_2!=undefined){
            create_a(appid,url_steam_app,"btn_green_white_innerfade",true,div_2);
            create_a("steamdb",url_steamdb_communityitems,"btn_green_white_innerfade",true,div_2);
            create_a("steamcardexchange",url_cardexchange,"btn_green_white_innerfade",true,div_2);
            var anchor=document.querySelectorAll('div.market_listing_nav>a');
            for(let i=0; i<anchor.length; i++){
                if(anchor[i].href.search(new RegExp("category_753_Game", "i"))!=-1){
                    anchor[i].href+="#p1_name_asc";
                    break;
                }
            }
        }
        var div_profile_small_header_text=document.querySelectorAll('div.profile_small_header_text')[0];//profile game badge
        let gamecard=document.querySelectorAll('img.gamecard');
        if(div_profile_small_header_text!=undefined){
            create_span("🛍️","profile_small_header_arrow",true,div_profile_small_header_text);
            create_a("Community Market",url_category_753_Game,"anchor",true,div_profile_small_header_text);
        }
        if(gamecard.length>0)document.querySelectorAll('div.badge_title')[0].innerText+=" ["+6000/gamecard.length+"]";
        var div_tab=document.querySelectorAll('div#mainContents>div#tabs')[0];//achievements
        if(div_tab!=undefined){
            var div_achievements=create_div(["tabOff","user_div_steam_info"],true,div_tab);
            create_a("steamdb achievements",url_steamdb_achievements,"steamdb",true,div_achievements);
        }
    }
    else if(url[0].host=="steamdb.info"){
        if(appid!=null){
            var app_links=document.querySelectorAll('nav.app-links')[0];
            var tab_communityitems=document.querySelectorAll('a#tab-communityitems')[0];
            if(app_links!=undefined){
                if(tab_communityitems!=undefined)create_a("Community Market",url_category_753_Game,"linkbar",true,app_links);
                create_a("curators",url_curatorsreviewing,"linkbar",true,app_links);
            }
        }
    }
    else if(url[0].host=="www.steamcardexchange.net"){
        let img_card=document.querySelectorAll('div.card>div>a>img');
        if(img_card.length>0)document.querySelectorAll('div.game-title>h1')[0].innerText+=" ["+6000/(img_card.length/2)+"]";
        let div_game_links=document.querySelectorAll('div.game-links')[0];
        if(div_game_links!=undefined){
            let button_blue=div_game_links.querySelectorAll('div.game-links>a.button-blue');
            for(let i=0; i<button_blue.length; i++){
                if(button_blue[i].innerText.search(new RegExp("STEAM MARKET", "i"))==0){
                    button_blue[i].href+="#p1_name_asc";
                    break;
                }
            }
            create_br(true,div_game_links);
            create_a("steamdb",url_steamdb_app,'button-blue',true,div_game_links);
        }
    }
})();