// ==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 data:image/svg+xml;base64,PHN2ZyB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB2aWV3Qm94PSIwIDAgMjAgMTYiIHdpZHRoPSI0MCIgaGVpZ2h0PSIzMiI+CjxjaXJjbGUgc3Ryb2tlLXdpZHRoPSIxLjVweCIgY3k9IjQuNSIgY3g9IjE1LjUiIHI9IjMuNzUiIGNsYXNzPSJzdHJva2UiIHN0cm9rZT0iI0JCQkJCQiIgZmlsbD0ibm9uZSI+PC9jaXJjbGU+CjxjaXJjbGUgY3g9IjE1LjUiIGN5PSI0LjUiIHI9IjEuODU1IiBjbGFzcz0iZmlsbCIgZmlsbD0iI0JCQkJCQiI+PC9jaXJjbGU+CjxwYXRoIGQ9Ik0xMS42NTYgNC4yTDEyLjc1IDcuMTRsMi44NjUgMS4zODctNS4xMyAzLjg1My0uODY3LTIuMDktMS43NzMtLjk0MnoiIGNsYXNzPSJmaWxsIiBmaWxsPSIjQkJCQkJCIj48L3BhdGg+CjxjaXJjbGUgY3k9IjEyLjUiIGN4PSI3LjUiIHI9IjMiIGNsYXNzPSJzdHJva2UiIHN0cm9rZT0iI0JCQkJCQiIgZmlsbD0ibm9uZSI+PC9jaXJjbGU+CjxyZWN0IHRyYW5zZm9ybT0ibWF0cml4KC45MjQzMiAuMzgxNiAtLjM4NzI3IC45MjE5NiAwIDApIiByeT0iMS41MjYiIHdpZHRoPSI5LjQ3NyIgeT0iNy4xNTUiIHg9IjMuNzY3IiBoZWlnaHQ9IjMuMDUzIiBjbGFzcz0iZmlsbCIgZmlsbD0iI0JCQkJCQiI+PC9yZWN0Pgo8L3N2Zz4=
// @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);
}
}
})();