// ==UserScript==
// @name search steam games name at bing(archive)
// @description for Rewards
// @namespace steam_name_bing
// @author Covenant
// @version 1.0
// @license MIT
// @homepage
// @match https://store.steampowered.com/app/*
// @match https://steamcommunity.com/app/*
// @match https://store.steampowered.com/curator/*
// @icon 
// @grant GM_setValue
// @grant GM_getValue
// @grant GM_registerMenuCommand
// @run-at document-end
// @noframes
// ==/UserScript==
var btn_bing;
var btn_name_ja;
var input_word;
var name_en;
var name_ja;
var json_textarea;
var json=GM_getValue("steam_app_name_json", {"app_name":{}});
var is_show_link=GM_getValue("is_show_link",true);
function create_style(textContent,id,class_name){
let style=create_node("style",class_name,true,document.body);
style.type='text/css';
style.id=id;
style.textContent=textContent;
return style;
}
const font_family_panel="font-family: 'Noto Sans Mono','Noto Mono','Cascadia Mono','Consolas','Liberation Mono','Monaco','Courier New','flag_patch','flag_white_patch','Noto Sans CJK JP','Meiryo','Yu Gothic','Microsoft JhengHei','symbol_sans','symbol2_sans','color_emoji','emoji_back',monospace;";
const font_family_code="font-family: 'Firple Slim','Noto Sans Mono','Noto Mono','Cascadia Code','Consolas','Liberation Mono','Monaco','Courier New','flag_patch','flag_white_patch','color_emoji','Noto Sans CJK JP','Meiryo','Yu Gothic','Microsoft JhengHei','symbol_sans','symbol2_sans','emoji_back',monospace;";
const font_family_steam="font-family: 'Motiva Sans',Arial, Helvetica,'flag_patch','flag_white_patch','color_emoji','Noto Sans CJK JP','Meiryo','Yu Gothic','Microsoft JhengHei','symbol_sans','symbol2_sans','emoji_back',sans-serif;";
const font_face_default=`
@font-face{font-family: 'color_emoji';src: local('Twemoji Mozilla'),/*url('file:///C:/Program Files/Mozilla Firefox/fonts/TwemojiMozilla.ttf'),*/local('Noto Color Emoji'),local('Segoe UI Emoji'),local('Apple Color Emoji');}
@font-face{font-family: 'symbol_sans';src: local('Segoe UI Symbol'),local('NotoSansSymbols-Regular'),local('NotoSansSymbols-Regular-Subsetted'),local('Noto Sans Symbols')/*,local('Apple Symbols')*/;}
@font-face{font-family: 'symbol2_sans';src: local('NotoSansSymbols2-Regular'),local('NotoSansSymbols-Regular-Subsetted2'),local('Meiryo');}
@font-face{font-family: 'emoji_back';src: local('Noto Color Emoji'),local('Toss Face Font Web'),local('Segoe UI Emoji');}
`;
var style_font_face=create_style(font_face_default,"gm_font_face_steam_name_bing",["user_gm_css","css_steam_name_bing"]);
var style_user_css=create_style(".user_input_local_bing{width: 70%;min-width: 32em;"+font_family_steam+"font-weight: 100;font-size: 110%;}","gm_user_css_steam_name_bing",["user_gm_css","css_steam_name_bing"]);
style_user_css.textContent+=`
.user_btn_steam{`+font_family_steam+`}
.user_textarea_json_steam{`+font_family_code+`font-size: 0.75rem;}
.user_textarea_json_steam{background: #1B2838;color: #ACB2B8;}
.user_textarea_json_steam{padding: 0.25em;min-width: 95%;min-height: 10em;border-style: inset;border-width: 0.2rem;border-color: #707070;}\n`;
function create_div(class_name,is_appendChild,node,refNode){
let div=create_node("div",class_name,is_appendChild,node,refNode);
div.style.backgroundSize='contain';
div.style.backgroundRepeat='no-repeat';
div.lang='ja';
return div;
}
function create_a(innerText,url,class_name,is_appendChild,node,refNode){
let anchor=create_node_text("a",innerText,class_name,is_appendChild,node,refNode);
anchor.href=url;
anchor.title=innerText;
if(url.search(new RegExp("javascript", "i"))!=0||url.indexOf(":")!=10)anchor.target="_blank";
return anchor;
}
function create_btn(innerText,class_name,is_appendChild,node,refNode){
let btn=create_node_text("button",innerText,class_name,is_appendChild,node,refNode);
return btn;
}
function create_input(placeholder,class_name,is_num,is_appendChild,node,refNode){
let input=create_node("Input",class_name,is_appendChild,node,refNode);
input.placeholder=placeholder;
input.type="text";input.lang='ja';
if(is_num)input.size="10";
if(is_num)input.setAttribute("maxlength", "10");
//if(is_num)input.setAttribute("oninput","this.value = this.value.replace(/[^0-9.]/g, '').replace(/(\\..*?)\\..*/g, '$1');");
if(is_num){
input.addEventListener("input", function (e) {
this.value = this.value.replace(/[^0-9.]/g, '').replace(/(\..*?)\..*/g, '$1');
});
}return input;
}
function create_textarea(placeholder,class_name,is_appendChild,node,refNode){
let textarea=create_node("textarea",class_name,is_appendChild,node,refNode);
textarea.placeholder=placeholder;
textarea.lang='ja';
return textarea;
}
function create_node(tagname,class_name,is_appendChild,node,refNode){
let element=document.createElement(tagname);
element.id="";
if(Array.isArray(class_name)){
for(let i=0; i<class_name.length; i++){element.classList.add(class_name[i]);}
}else if(typeof class_name==='string'){element.classList.add(class_name);}
if(is_appendChild){node.appendChild(element);}else{node.insertBefore(element, refNode);}
return element;
}
function create_node_text(tagname,innerText,class_name,is_appendChild,node,refNode){
let element = create_node(tagname,class_name,is_appendChild,node,refNode);
element.innerText=innerText;
element.lang='ja';
return element;
}
function fn_url(url){
let obj_url=new URL(url);
let params=obj_url.searchParams;
return [obj_url,params];
}
async function fn_clipboard_w(str){
try{
await navigator.clipboard.writeText(str);
}catch(e){alert(e.message);}
finally{}
}
//console.log("break");
async function fn_re_steam_appdetails(response){
let url=fn_url(response.url);
let lang=url[1].get('l');
if(response.status==200){
let json=await response.json();
let appid=steam_app_id(response.url);
let data = json[appid];
let { name, supported_languages, categories } = data.data;
if(lang=="english"){
name_en=name;
input_word.value=name;
}else if(lang=="japanese")name_ja=name;
}else{
if(lang=="english"){
btn_bing.innerText+=" "+response.status;
}
//input_word.value=document.head.querySelectorAll('title')[0].innerText.replace(/ on Steam/i, '').replace(/Steam:/i, '').replace(/Steam - /i, '');
console.log("appdetails response.status: "+response.status+response.responseHeaders);
}
}
function fn_fetch(url,fn){
fetch(url).then((response) => {
console.log([
"fetch",
response.status,
response.statusText,
response.readyState,//
response.responseHeaders,//
response.ok,
response.url].join("\n")
);
fn(response.clone());
return response.json();
}).then(data => {
//console.log(data);
}).catch(err => {
console.log(err);
});
}
function steam_app_id(url){
url=fn_url(url);
let host=url[0].host;
let pathname=url[0].pathname;
let 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
}
return null;
}
function fn_btn_search(){
window.open('https://www.bing.com/search?q='+encodeURIComponent(input_word.value), '_blank');
//redirectWindow.location;
}
function fn_btn_name_ja(){
//let text=navigator.clipboard.readText().then(clipText => {tmp=clipText});
input_word.value=name_ja;
}
function fn_btn_name_save(){
let appid=steam_app_id(document.location);
let url=fn_url(document.location);
if(url[0].host=="store.steampowered.com"&&url[0].pathname.search(/\/app\/\d+.+/i)==0){
json["app_name"][appid]={};
if(name_en!=undefined){
json["app_name"][appid]["en"]=name_en;
}
if(name_ja!=undefined){
if(name_ja!=name_en)json["app_name"][appid]["ja"]=name_ja;
}
}else if(url[0].host=="steamcommunity.com"&&url[0].pathname.search(/\/app\/\d+.+/i)==0){
let div_apphub_AppName=document.querySelectorAll("div.apphub_AppName")[0].innerText;
json["app_name"][appid]={};
json["app_name"][appid]["delisted"]=div_apphub_AppName;
}
GM_setValue('steam_app_name_json',json);
this.innerText="save name✔️";
console.log(json);
}
function fn_btn_remove(){
let appid=steam_app_id(document.location);
delete json["app_name"][appid];
GM_setValue('steam_app_name_json',json);
}
function fn_btn_json_copy(){
fn_clipboard_w(json_textarea.value);
}
function fn_btn_json_save(){
try{
let json=JSON.parse(json_textarea.value);
if(json["app_name"]==undefined){throw (new Error("Thrown if the string to parse is not valid JSON."));}
GM_setValue('steam_app_name_json',json);
}catch(e){
alert(e.message);
}finally{}
}
function main_01(){
let title=document.querySelectorAll('div.apphub_HeaderStandardTop')[0];
let game_meta_data=document.querySelectorAll('div.game_meta_data');
let appid=steam_app_id(document.location);
GM_registerMenuCommand("show link"+(is_show_link?"✔️":"❌"), () => {
GM_setValue("is_show_link", !is_show_link);
location.reload();
});
if(title!=undefined){//steam game page
let div_print=create_div("user",true,title);
input_word=create_input("game_name",["searchbox","user_input_local_bing"],false,true,div_print);
fn_fetch("https://store.steampowered.com/api/appdetails?appids="+appid+"&l=english",fn_re_steam_appdetails);
fn_fetch("https://store.steampowered.com/api/appdetails?appids="+appid+"&l=japanese",fn_re_steam_appdetails);
btn_bing=create_btn("bingで検索",["btnv6_blue_hoverfade","user_btn_steam"],true,div_print);
btn_bing.addEventListener('click',() => {fn_btn_search();});
btn_name_ja=create_btn("name_ja",["btnv6_blue_hoverfade","user_btn_steam"],true,div_print);
btn_name_ja.disabled=true;
btn_name_ja.addEventListener('click',() => {fn_btn_name_ja();});
let btn_name_save=create_btn("save name"+(json["app_name"][appid]!=undefined?"✔️":""),["btnv6_blue_hoverfade","user_btn_steam"],true,div_print);
btn_name_save.disabled=true;
btn_name_save.addEventListener('click',fn_btn_name_save);
window.setTimeout(( () => {
if(name_en==undefined&&name_ja==undefined){//429
input_word.value=document.querySelectorAll('div#appHubAppName')[0].innerText;
}else if(name_ja==name_en){
btn_name_ja.style.setProperty("display", "none");
}else{btn_name_ja.disabled=false;}
btn_name_save.disabled=false;
}),3000);
window.setTimeout(( () => {
if(is_show_link){
let div_heading=create_div(['block',"heading","sans_steam"],true,game_meta_data[0]);
div_heading.innerText="bingで検索";
let div_json=create_div(['block',"user_div_steam_info"],true,game_meta_data[0]);
for(let key_id in json["app_name"]){
for(let key_lang in json["app_name"][key_id]){
let str_name=json["app_name"][key_id][key_lang];
let link_bing=create_a(str_name,"https://www.bing.com/search?q="+encodeURIComponent(str_name),['linkbar',"external","sans_steam"],true,div_json);
link_bing.title=key_id;
//console.log(key_lang + ' - ' + json["app_name"][key_id][key_lang])
}
}
create_node("br",[],true,div_json);
let btn_json_copy=create_btn("copy json",["btnv6_blue_hoverfade","user_btn_steam"],true,div_json);
btn_json_copy.addEventListener('click',fn_btn_json_copy);
let btn_json_save=create_btn("save bak json from text",["btnv6_blue_hoverfade","user_btn_steam"],true,div_json);
btn_json_save.addEventListener('click',fn_btn_json_save);
json_textarea=create_textarea("json={\"app_name\":{}}",["user_textarea_json_steam"],true,div_json);
json_textarea.value=JSON.stringify(json,"1065970",2);
let btn_remove=create_btn("remove: "+appid,["btnv6_blue_hoverfade","user_btn_steam"],true,div_json);
btn_remove.addEventListener('click',fn_btn_remove);
}
}),1000);
}
}
(function() {
'use strict';
let url=fn_url(document.location);
window.onload = function(){
if(url[0].host=="store.steampowered.com"){
if(url[0].pathname.search(/\/app\/\d+.+/i)==0){
main_01();//console.log("/\/app\/\d+.+/")
}
}else if(url[0].host=="steamcommunity.com"){
if(url[0].pathname.search(/\/app\/\d+.+/i)==0){
let div_apphub_AppDetails=document.querySelectorAll("div.apphub_AppDetails")[0];
let btn_name_save=create_btn("save name",["btnv6_blue_hoverfade","user_btn_steam"],true,div_apphub_AppDetails);
btn_name_save.addEventListener('click',fn_btn_name_save);
}
}
};
})();