您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
WEB端Steam小助手,集合多种功能如Steam批量留言,点赞,好友管理,喜加一...,佛系更新中...欢迎提出您的建议或者共同学习交流
// ==UserScript== // @name Steam assistant(Steam小助手) // @description WEB端Steam小助手,集合多种功能如Steam批量留言,点赞,好友管理,喜加一...,佛系更新中...欢迎提出您的建议或者共同学习交流 // @version 1.2.3.4.5 // @date 2020.6.30 // @source https://github.com/Mikuof39/Steam-assistant-Steam- // @homepage https://steamcommunity.com/sharedfiles/filedetails/?id=1993903275 // @supportURL https://greasyfork.org/zh-CN/scripts/397073/feedback // @author Miku39 // @license GPL License // @namespace https://steamcommunity.com/id/miku-39/ // @namespace https://www.tampermonkey.net/ // @namespace https://greasyfork.org/ // @icon https://store.steampowered.com/favicon.ico // @icon64 https://steamcommunity-a.akamaihd.net/public/shared/images/responsive/share_steam_logo.png // @note CSS----------------------------------------------------------------------- // @resource css_layui https://www.layuicdn.com/layui-v2.5.6/css/layui.css // @resource css_laydate https://www.layuicdn.com/layui-v2.5.6/css/modules/laydate/default/laydate.css?v=5.0.9 // @resource css_layer https://www.layuicdn.com/layui-v2.5.6/css/modules/layer/default/layer.css?v=3.1.1 // @resource css_layui_Modules https://www.layuicdn.com/layui-v2.5.6/css/modules/code.css // @resource css_fontAwesome https://cdn.bootcss.com/font-awesome/4.7.0/css/font-awesome.min.css // @note JS----------------------------------------------------------------------- // @resource JS_highstock https://code.highcharts.com.cn/highstock/highstock.js // @resource JS_highstock_exporting https://code.highcharts.com.cn/highcharts/modules/exporting.js // @resource JS_highstock_oldie https://code.highcharts.com.cn/highcharts/modules/oldie.js // @resource JS_highstock_networkgraph https://code.highcharts.com.cn/highcharts/modules/networkgraph.js // @resource JS_highstock_zh_CN https://code.highcharts.com.cn/highcharts-plugins/highcharts-zh_CN.js // @resource JS_layui https://www.layuicdn.com/layui-v2.5.6/layui.all.js // @resource JS_localforage https://cdnjs.cloudflare.com/ajax/libs/localforage/1.7.3/localforage.min.js // @resource JS_draw https://cdnjs.cloudflare.com/ajax/libs/pixi.js/5.2.4/pixi.js // @resource JS_animate https://code.createjs.com/1.0.0/tweenjs.js // @resource JS_sound https://code.createjs.com/1.0.0/soundjs.js // @resource JS_render https://cdnjs.cloudflare.com/ajax/libs/three.js/110/three.js // @resource JS_multithreading https://gitlab.com/hordesolutions/Hamsters.js/-/raw/master/build/hamsters.min.js // @resource JS_pep https://code.jquery.com/pep/0.4.3/pep.js // @resource JS_babylon https://preview.babylonjs.com/babylon.js // @resource JS_babylon_loaders https://preview.babylonjs.com/loaders/babylonjs.loaders.min.js // @resource Jquery_localizationtool https://greasyfork.org/scripts/403927-jquery-localizationtool-js/code/jquerylocalizationTooljs.js?version=808323 // @note 运行页面-> 社区 // @include /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/friends\/?$/ // @include /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/friends\/?(add|pending|blocked|coplay|broadcast_moderator)?\/?$/ // @include /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/(following|groups|groups\/pending)\/?$/ // @include /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/friends\/?([A-Za-z0-9$/-_.+!*'(),])+$/ // @note 运行页面-> 创意工坊-我的 // @include /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/myworkshopfiles\/\?appid=+[0-9]+&browsefilter=myfavorites$/ // @note 运行页面-> 创意工坊-我的收藏 // @include /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/myworkshopfiles\/\?appid=+[0-9]+&browsefilter=myfavorites$/ // @note 运行页面-> 创意工坊-我的订阅 // @include /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/myworkshopfiles\/\?appid=+[0-9]+&browsefilter=myfavorites$/ // @note 运行页面-> 创意工坊-运行过的 // @include /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/myworkshopfiles\/\?appid=+[0-9]+&browsefilter=myfavorites$/ // @note 脚本功能----------------------------------------------------------------------- // @grant GM_xmlhttpRequest // @grant GM_getResourceText // @grant GM_getResourceURL // @grant GM_registerMenuCommand // @grant GM_unregisterMenuCommand // @grant GM_download // @grant GM_openInTab // @grant GM_addValueChangeListener // @grant GM_removeValueChangeListener // @grant GM_getTab // @grant GM_saveTab // @grant GM_getTabs // @grant GM_setClipboard // @grant GM_notification // @grant GM_listValues // @grant GM_info // @note Cdn----------------------------------------------------------------------- // @connect code.highcharts.com // @connect code.highcharts.com.cn // @connect www.layuicdn.com // @connect cdnjs.cloudflare.com // @connect cdn.90so.net // @connect www.jsdelivr.com // @connect cdn.bootcss.com // @connect stackpath.bootstrapcdn.com // @connect greasyfork.org // @connect github.com // @connect www.bootcdn.cn // @connect cdn.jsdelivr.net // @note Translate----------------------------------------------------------------- // @connect www.deepl.com // @connect api.deepl.com // @connect translate.google.cn // @connect translate.google.com // @connect fanyi.baidu.com // @connect api.fanyi.baidu.com //百度通用翻译API HTTP http://fanyi-api.baidu.com/api/trans/product/prodinfo#0 // @connect fanyi-api.baidu.com //百度通用翻译API HTTPS https://blog.csdn.net/dianfu2892/article/details/101467066 // @connect fanyi.youdao.com // @connect fanyi.so.com // @connect fanyi.qq.com // @connect fanyi.sogou.com // @connect cn.bing.com //https://cn.bing.com/translator/ // @connect hjdict.com //http://www.hjdict.com/app/trans // @connect fanyi.dict.cn // @note Api----------------------------------------------------------------------- // @connect brushes8.com // @connect api.help.bj.cn // @connect api.avatardata.cn //https://www.avatardata.cn/Docs // @connect route.showapi.com //会员/免费 https://www.showapi.com/api/apiList // @connect zhaiyan.2cys.com // @connect api.dongmanxingkong.com // @connect api.pingcc.cn // @connect 47.114.147.221 // @connect www.dmoe.cc // @connect api.mz-moe.cn // @connect sinaimg.cn // @connect self // @connect * // @noframes // @run-at document-start // ==/UserScript== /** */ //---------------------------------------------------------------------------------------------------------------------------------------------------- //模块: databaseConf.js class DB -> ui.js UI::initUI() /* 全局数据库对象 */ var g_db,g_db1,g_db2,g_db3,g_db4; //---------------------------------------------------------------------------------------------------------------------------------------------------- //模块: databaseConf.js -> ui.js UI::initUI() const URLs = { //您的好友 g_friendUrlRegExp: /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/friends\/?$/, //添加好友 g_otherUrlRegExp1_1: /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/friends\/add?\/?$/, //待处理邀请 g_otherUrlRegExp1_2: /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/friends\/pending?\/?$/, //已屏蔽 g_otherUrlRegExp1_3: /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/friends\/blocked?\/?$/, //近期共同游戏的玩家 g_otherUrlRegExp1_4: /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/friends\/coplay?\/?$/, //直播版主 g_otherUrlRegExp1_5: /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/friends\/broadcast_moderator?\/?$/, //关注的玩家 g_otherUrlRegExp2_1: /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/following\/?$/, //您的组 g_otherUrlRegExp2_2: /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/groups\/?$/, //待处理邀请 g_otherUrlRegExp2_3: /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/groups\/pending\/?$/, // g_otherUrlRegExp3: /^https?:\/\/steamcommunity.com\/(id\/+[A-Za-z0-9$-_.+!*'(),]+|profiles\/7656119[0-9]{10})\/friends\/?([A-Za-z0-9$/-_.+!*'(),])+$/, }; //---------------------------------------------------------------------------------------------------------------------------------------------------- //模块: databaseConf.js -> ui.js UI::initUI() const g_steamId64RegExp = /7656119[0-9]{10}/; //---------------------------------------------------------------------------------------------------------------------------------------------------- //模块: externalApis.js class intelligenceAI, class SteamDB, class friendActivity, class UI, class externalApis, class App /* 全局对象 */ var gc_res = null; var gc_ai = null; var gc_steamdb = null; var gc_friAct = null; var gc_menu_friends_ui = null; //您的好友 var gc_menu_friends_invite_ui = null; //待处理邀请 var gc_menu_shielding_ui = null; //已屏蔽 var gc_menu_gameFriend_ui = null; //近期共同游戏的玩家 var gc_menu_liveAdmin_ui = null; //直播版主 var gc_menu_following_Players_ui = null; //关注的玩家 var gc_menu_groups_ui = null; //您的组 var gc_menu_groups_invite_ui = null; //待处理邀请 var gc_exApis = null; var gc_app = null; //---------------------------------------------------------------------------------------------------------------------------------------------------- //模块: utility.js -> registeMenu() 和 unRegisteMenu()使用 /* 全局对象 */ var g_arrMenuID = [5]; function fixConfInfo(i,steamID){ /*修复配置信息*/ var isFix = false; if (g_conf[i].delay < 0){ isFix = true; g_conf[i].delay = 4; } if (g_conf[i].strNoOperate == ""){ isFix = true; g_conf[i].strNoOperate = "(不留言)"; } if (g_conf[i].strRemarkPlaceholder == ""){ isFix = true; g_conf[i].strRemarkPlaceholder = "{name}"; } return isFix; } function newUserGuide(steamID){ /*新用户引导*/ /*新手引导*/ /*console.log("欢迎使用Steam小助手. 当前版本: 更新时间:");*/ /*显示简短的教程界面*/ /*console.log("是否进入教程?");*/ /*console.log("文字教程: 链接到指南 视频教程: 链接");*/ var length = g_conf.push(g_default_configuration); /*添加默认配置信息作为新配置信息*/ g_conf[length-1].steamID = steamID; /*设置当前用户的steamID,作为当前用户的配置信息*/ } function readUserConfInfoToCurrConfInfo(i){ /*读取用户配置信息到当前配置信息处[0]*/ g_conf[0].autoLogin = g_conf[i].autoLogin; g_conf[0].delay = g_conf[i].delay; g_conf[0].strNoOperate = g_conf[i].strNoOperate; g_conf[0].strRemarkPlaceholder = g_conf[i].strRemarkPlaceholder; g_conf[0].steamID = g_conf[i].steamID; } function getProfilesInfo(){ /*获取配置文件信息*/ } function readConfInfo(steamID){ /*读取已保存的对应配置信息*/ if(g_conf.length == 1){ /*说明没有格外的配置信息*/ newUserGuide(steamID); } else { for (let i = 1; i < g_conf.length; i++) { /*遍历所有的配置信息*/ if(g_conf[i].steamID == steamID){ readUserConfInfoToCurrConfInfo(i); /*读取用户配置信息到当前配置信息处[0]*/ return true; } } /*如果没有查找到,则新建用户引导*/ newUserGuide(steamID); return true; } } function saveConfInfo(steamID){ /*保存最新的配置信息*/ if(fixConfInfo(0,steamID)){ /*尝试 修复配置信息*/ console.log("尝试保存的配置信息无效,已经恢复至默认值. 请检查..."); } } function initConfInfo(i,steamID){ /*配置信息初始化(恢复默认)*/ g_conf[i].autoLogin = g_default_configuration.autoLogin; g_conf[i].delay = g_default_configuration.delay; g_conf[i].strNoOperate = g_default_configuration.strNoOperate; g_conf[i].strRemarkPlaceholder = g_default_configuration.strRemarkPlaceholder; g_conf[i].steamID = g_default_configuration.steamID; } function exportConfInfo(steamID){ /*导出配置信息(到文件)*/ if(fixConfInfo(0,steamID)){ /*尝试 修复配置信息*/ console.log("尝试导出的配置信息无效,已经恢复至默认值. 请检查..."); } /*从0号中读取出来,导出到文件*/ } function importConfInfo(steamID){ /*导入配置信息(选择文件并读取)*/ if(fixConfInfo(0,steamID)){ /*尝试 修复配置信息*/ console.log("尝试导入的配置信息无效,已经恢复至默认值. 请检查..."); } /*保存配置文件*/ } //------------------------------------------------------------------------------------------------------------- class DB{ constructor(){ this.DBstore = []; //数据库存储数组(多实例) this.DBindex = 0; //当前数据库索引 if(arguments.length == 1){ this._constructor(arguments[0]); }else if(arguments.length == 2){ this._constructor(arguments[0],arguments[1]); } } _constructor(DBConfig,isTest = true){ //默认创建新的数据库 //数据库配置,是否启用测试 if(isTest == true) this.Test(); this.initAndCreateNewDBInstance(DBConfig); } use(DBname){ //指定要使用的数据库 for (let i = 0; i < this.DBstore.length; i++) { if(DBname == DBstore[i]._dbInfo.name){ this.DBindex = i; return DBstore[i]; } } return null; } async initCurrentDBInstance(DBConfig){ //单数据库 //初始化当前数据库实例 var obj; if(typeof DBConfig == "object"){ localforage.config(DBConfig); this.DBindex = this.DBstore.push(obj) -1; // obj = localforage; }else{ console.log("参数不合法,请检查..."); } await obj.ready().then(function() { // 当 localforage 将指定驱动初始化完成时,此处代码运行 console.log("数据库初始化成功! 当前使用的是: "+ localforage.driver()); }).catch(function (e) { // 当没有可用的驱动时,ready()将会失败 console.log("数据库初始化失败(没有可用的驱动)! " + e); // No available storage method found. }); return obj; } initAndCreateNewDBInstance(DBConfig){ //多数据库 //初始化并创建新的数据库实例 var obj; if(typeof DBConfig == "object"){ obj = localforage.createInstance(DBConfig); this.DBindex = this.DBstore.push(obj) -1; // }else{ console.log("参数不合法,请检查..."); } return obj; } async dropDBInstance(name){ //删除数据库实例 await localforage.dropInstance({ name: name }).then(function() { //console.log('删除数据库成功!'); }); } async Read(key){ //读取数据 var data; await this.DBstore[this.DBindex].getItem(key).then(function(value) { // 当离线仓库中的值被载入时,此处代码运行 //console.log("数据读取成功. "+ value); data = value; }).catch(function(err) { // 当出错时,此处代码运行 console.log("数据读取失败! "+ err); }); return data; } async ReadAll(){ //读取所有数据(迭代),返回包含所有数据的数组 var data = []; await this.DBstore[this.DBindex].iterate(function(value, key, iterationNumber) { // 此回调函数将对所有 key/value 键值对运行 //console.log([key, value]); data.push([key, value]); }).then(function() { //console.log("读取所有数据成功."+ [key, value]); }).catch(function(err) { // 当出错时,此处代码运行 console.log("读取所有数据失败!"+ err); }); return data; } async Write(key,value){ //写入数据 var status = true; // 不同于 localStorage,你可以存储非字符串类型 await this.DBstore[this.DBindex].setItem(key, value).then(function(value) { //console.log("数据写入成功. "+ value); }).catch(function(err) { // 当出错时,此处代码运行 status = false; console.log("数据写入失败! "+ err); }); return status; } async Remove(key){ //删除数据 var status = true; await this.DBstore[this.DBindex].removeItem(key).then(function() { // 当值被移除后,此处代码运行 //console.log('删除数据成功.'); }).catch(function(err) { // 当出错时,此处代码运行 status = false; console.log('删除数据失败!'+ err); }); return status; } async RemoveAll(){ //删除所有数据(重置数据库->删除后数据库是空的) var status = true; await this.DBstore[this.DBindex].clear().then(function() { // 当数据库被全部删除后,此处代码运行 //console.log('删除所有数据成功!'); }).catch(function(err) { // 当出错时,此处代码运行 status = false; console.log('删除所有数据失败!'+ err); }); return status; } async getLength(){ //获取已存储的所有数据总条数(长度) var length; await this.DBstore[this.DBindex].length().then(function(numberOfKeys) { // 输出数据库的大小 //console.log(numberOfKeys); length = numberOfKeys; }).catch(function(err) { // 当出错时,此处代码运行 console.log(err); }); return length; } async getKeyNameByIndex(index){ //通过下标(index)获取对应的Key名 //此方法很怪异,于是进行重写 // var name; // await this.DBstore[this.DBindex].key(index).then(function(keyName) { // // key 名 // //console.log(keyName); // name = keyName; // }).catch(function(err) { // // 当出错时,此处代码运行 // console.log("getKeyNameByIndex()失败!" + err); // }); // return name; var arr_name = await this.getAllKeyName(); if(index < 0 || index >= arr_name.length){ console.log("getKeyNameByIndex()失败! 参数不正确: " +index); return null; } return arr_name[index]; } async getAllKeyName(){ // 返回 包含所有 key 名的数组 var key; await this.DBstore[this.DBindex].keys().then(function(keys) { // console.log(keys); key = keys; }).catch(function(err) { // 当出错时,此处代码运行 console.log("getAllKeyName()失败!" + err); }); return key; } Test(){ //测试当前浏览器的数据库支持情况 if(localforage.supports(localforage.INDEXEDDB) == true){ console.log("当前浏览器支持 IndexedDB."); }else{ console.log("当前浏览器不支持 IndexedDB!"); } if(localforage.supports(localforage.WEBSQL) == true){ console.log("当前浏览器支持 WEBSQL."); }else{ console.log("当前浏览器不支持 WEBSQL!"); } if(localforage.supports(localforage.LOCALSTORAGE) == true){ console.log("当前浏览器支持 LOCALSTORAGE."); }else{ console.log("当前浏览器不支持 LOCALSTORAGE!"); } } } //--------------------------------------------------------------------------------------- // class GameId { // static parseId(id) { // if (!id) { return null; } // let intId = parseInt(id); // if (!intId) { return null; } // return intId; // } // static getAppid(text) { // if (!text) { return null; } // if (text instanceof HTMLElement) { // let appid = text.dataset.dsAppid; // if (appid) return GameId.parseId(appid); // text = text.href; // if (!text) return null; // } // // app, market/listing // let m = text.match(/(?:store\.steampowered|steamcommunity)\.com\/(?:app|market\/listings)\/(\d+)\/?/); // return m && GameId.parseId(m[1]); // } // static getSubid(text) { // if (!text) { return null; } // if (text instanceof HTMLElement) { // let subid = text.dataset.dsPackageid; // if (subid) return GameId.parseId(subid); // text = text.href; // if (!text) return null; // } // let m = text.match(/(?:store\.steampowered|steamcommunity)\.com\/sub\/(\d+)\/?/); // return m && GameId.parseId(m[1]); // } // static getBundleid(text) { // if (!text) { return null; } // if (text instanceof HTMLElement) { // let bundleid = text.dataset.dsBundleid; // if (bundleid) return GameId.parseId(bundleid); // text = text.href; // if (!text) return null; // } // let m = text.match(/(?:store\.steampowered|steamcommunity)\.com\/bundle\/(\d+)\/?/); // return m && GameId.parseId(m[1]); // } // static trimStoreId(storeId) { // return Number(storeId.slice(storeId.indexOf('/') + 1)); // } // static getAppidImgSrc(text) { // if (!text) { return null; } // let m = text.match(/(steamcdn-a\.akamaihd\.net\/steam|steamcommunity\/public\/images)\/apps\/(\d+)\//); // return m && GameId.parseId(m[2]); // } // static getAppidUriQuery(text) { // if (!text) { return null; } // let m = text.match(/appid=(\d+)/); // return m && GameId.parseId(m[1]); // } // static getAppids(text) { // let regex = /(?:store\.steampowered|steamcommunity)\.com\/app\/(\d+)\/?/g; // let res = []; // let m; // while ((m = regex.exec(text)) != null) { // let id = GameId.parseId(m[1]); // if (id) { // res.push(id); // } // } // return res; // } // static getAppidFromId(text) { // if (!text) { return null; } // let m = text.match(/game_(\d+)/); // return m && GameId.parseId(m[1]); // } // static getAppidFromGameCard(text) { // if (!text) { return null; } // let m = text.match(/\/gamecards\/(\d+)/); // return m && GameId.parseId(m[1]); // } // } // // todo use https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/API/storage // class LocalStorage { // static get(key, defaultValue) { // let item = localStorage.getItem(key); // if (!item) return defaultValue; // try { // return JSON.parse(item); // } catch (err) { // return defaultValue; // } // } // static set(key, value) { // localStorage.setItem(key, JSON.stringify(value)); // } // static has(key) { // return localStorage.getItem(key) !== null; // } // static remove(key) { // localStorage.removeItem(key); // } // static keys() { // let result = []; // for (let i = localStorage.length - 1; i >= 0; --i) { // result.push(localStorage.key(i)); // } // return result; // } // static clear() { // localStorage.clear(); // } // } // class SyncedStorage { // /** // * browser.storage.sync limits // * QUOTA_BYTES = 102400 // 100KB // * QUOTA_BYTES_PER_ITEM = 8192 // 8KB // * MAX_ITEMS = 512 // * MAX_WRITE_OPERATIONS_PER_HOUR = 1800 // * MAX_WRITE_OPERATIONS_PER_MINUTE = 120 // */ // static has(key) { // return Object.prototype.hasOwnProperty.call(this.cache, key); // } // static get(key) { // if (typeof this.cache[key] == 'undefined') { // if (typeof this.defaults[key] == 'undefined') { // console.warn(`Unrecognized SyncedStorage key '${key}'`); // } // return this.defaults[key]; // } // return this.cache[key]; // } // static set(key, value) { // this.cache[key] = value; // return this.adapter.set({ [key]: value, }); // // this will throw if MAX_WRITE_*, MAX_ITEMS, QUOTA_BYTES* are exceeded // } // static import(entries) { // for (let [key, value] of Object.entries(entries)) { // this.cache[key] = value; // } // return this.adapter.set(entries); // } // static remove(key) { // if (typeof this.cache[key]) { // delete this.cache[key]; // } // return this.adapter.remove(key); // // can throw if MAX_WRITE* is exceeded // } // static keys(prefix='') { // return Object.keys(this.cache).filter(k => k.startsWith(prefix)); // } // static entries() { // return Object.entries(this.cache); // } // static clear() { // this.cache = {}; // return this.adapter.clear(); // // can throw if MAX_WRITE* is exceeded // } // // load whole storage and make local copy // static async init() { // browser.storage.onChanged.addListener(changes => { // for (let [key, { newValue: val, }] of Object.entries(changes)) { // this.cache[key] = val; // } // if (typeof ContextMenu === "function" && Object.keys(changes).some(key => key.startsWith("context_"))) { // ContextMenu.update(); // } // }); // let storage = await this.adapter.get(null); // Object.assign(this.cache, storage); // return this.cache; // } // static then(onDone, onCatch) { // return this.init().then(onDone, onCatch); // } // static async quota() { // let maxBytes = this.adapter.QUOTA_BYTES; // let bytes = await this.adapter.getBytesInUse(); // return bytes / maxBytes; // float 0.0 (0%) -> 1.0 (100%) // } // } // SyncedStorage.adapter = browser.storage.sync || browser.storage.local; // SyncedStorage.cache = {}; // SyncedStorage.defaults = { // 'language': "english", // 'version': Info.version, // 'version_show': true, // 'highlight_owned_color': "#00ce67", // 'highlight_wishlist_color': "#0491bf", // 'highlight_coupon_color': "#a26426", // 'highlight_inv_gift_color': "#800040", // 'highlight_inv_guestpass_color': "#513c73", // 'highlight_notinterested_color': "#4f4f4f", // 'highlight_collection_color': "#856d0e", // 'highlight_waitlist_color': "#4c7521", // 'tag_owned_color': "#00b75b", // 'tag_wishlist_color': "#0383b4", // 'tag_coupon_color': "#c27120", // 'tag_inv_gift_color': "#b10059", // 'tag_inv_guestpass_color': "#65449a", // 'tag_notinterested_color': "#4f4f4f", // 'tag_collection_color': "#856d0e", // 'tag_waitlist_color': "#4c7521", // 'highlight_owned': true, // 'highlight_wishlist': true, // 'highlight_coupon': false, // 'highlight_inv_gift': false, // 'highlight_inv_guestpass': false, // 'highlight_notinterested': false, // 'highlight_excludef2p': false, // 'highlight_notdiscounted': false, // 'highlight_collection': true, // 'highlight_waitlist': true, // 'tag_owned': false, // 'tag_wishlist': false, // 'tag_coupon': false, // 'tag_inv_gift': false, // 'tag_inv_guestpass': false, // 'tag_notinterested': true, // 'tag_collection': false, // 'tag_waitlist': false, // 'tag_short': false, // 'hide_owned': false, // 'hide_ignored': false, // 'hide_dlcunownedgames': false, // 'hide_wishlist': false, // 'hide_cart': false, // 'hide_notdiscounted': false, // 'hide_mixed': false, // 'hide_negative': false, // 'hide_priceabove': false, // 'priceabove_value': "", // 'hidetmsymbols': false, // 'showlowestprice': true, // 'showlowestprice_onwishlist': true, // 'showlowestpricecoupon': true, // 'showallstores': true, // 'stores': [], // 'override_price': "auto", // 'showregionalprice': "mouse", // 'regional_countries': ["us", "gb", "ru", "br", "au", "jp"], // 'show_es_homepagetabs': true, // 'showmarkettotal': false, // 'showsteamrepapi': true, // 'showmcus': true, // 'showoc': true, // 'showhltb': true, // 'showyoutube': true, // 'showtwitch': true, // 'showpcgw': true, // 'showcompletionistme': false, // 'showprotondb': false, // 'showviewinlibrary': false, // 'showsteamcardexchange': false, // 'showitadlinks': true, // 'showsteamdb': true, // 'showbartervg': false, // 'showastatslink': true, // 'showyoutubegameplay': true, // 'showyoutubereviews': true, // 'showwsgf': true, // 'exfgls': true, // 'customize_apppage': { // "recentupdates": true, // "reviews": true, // "about": true, // "contentwarning": true, // "steamchart": true, // "steamspy": true, // "surveys": true, // "sysreq": true, // "legal": true, // "morelikethis": true, // "recommendedbycurators": true, // "customerreviews": true // }, // 'customize_frontpage': { // "featuredrecommended": true, // "specialoffers": true, // "trendingamongfriends": true, // "discoveryqueue": true, // "browsesteam": true, // "curators": true, // "morecuratorrecommendations": true, // "recentlyupdated": true, // "fromdevelopersandpublishersthatyouknow": true, // "popularvrgames": true, // "homepagetabs": true, // "gamesstreamingnow": true, // "under": true, // "updatesandoffers": true, // "homepagesidebar": true // }, // //'show_keylol_links': false, // not in use, option is commented out // 'show_package_info': false, // 'show_steamchart_info': true, // 'show_steamspy_info': true, // 'show_early_access': true, // 'show_alternative_linux_icon': false, // 'show_itad_button': false, // 'skip_got_steam': false, // 'hideaboutlinks': false, // 'installsteam': "show", // 'openinnewtab': false, // 'keepssachecked': false, // 'showemptywishlist': true, // 'showusernotes': true, // 'showwishliststats': true, // 'user_notes': {}, // 'replaceaccountname': true, // 'showfakeccwarning': true, // 'showlanguagewarning': true, // 'showlanguagewarninglanguage': "english", // 'homepage_tab_selection': "remember", // 'homepage_tab_last': null, // 'send_age_info': true, // 'mp4video': false, // 'horizontalscrolling': true, // 'showsupportinfo': true, // 'showdrm': true, // 'regional_hideworld': false, // 'showinvnav': true, // 'quickinv': true, // 'quickinv_diff': -0.01, // 'community_default_tab': "", // 'showallachievements': false, // 'showallstats': true, // 'showachinstore': true, // 'showcomparelinks': false, // 'hideactivelistings': false, // 'showlowestmarketprice': true, // 'hidespamcomments': false, // 'spamcommentregex': "[\\u2500-\\u25FF]", // 'wlbuttoncommunityapp': true, // 'removeguideslanguagefilter': false, // 'disablelinkfilter': false, // 'showallfriendsthatown': false, // 'sortfriendsby': "default", // 'sortreviewsby': "default", // 'sortgroupsby': "default", // 'show1clickgoo': true, // 'show_profile_link_images': "gray", // 'profile_steamrepcn': true, // 'profile_steamgifts': true, // 'profile_steamtrades': true, // 'profile_bartervg': true, // 'profile_steamrep': true, // 'profile_steamdbcalc': true, // 'profile_astats': true, // 'profile_backpacktf': true, // 'profile_astatsnl': true, // 'profile_steamid': true, // 'profile_custom_link': [ // { 'enabled': true, 'name': "Google", 'url': "google.com/search?q=[ID]", 'icon': "www.google.com/images/branding/product/ico/googleg_lodp.ico", }, // ], // 'group_steamgifts': true, // 'steamcardexchange': true, // 'purchase_dates': true, // 'show_badge_progress': true, // 'show_coupon': true, // 'show_wishlist_link': true, // 'show_wishlist_count': true, // 'show_progressbar': true, // 'show_backtotop': false, // 'profile_showcase_twitch': true, // 'profile_showcase_own_twitch': false, // 'profile_showcase_twitch_profileonly': false, // 'itad_import_library': false, // 'itad_import_wishlist': false, // 'add_to_waitlist': false, // 'context_steam_store': false, // 'context_steam_market': false, // 'context_itad': false, // 'context_bartervg': false, // 'context_steamdb': false, // 'context_steamdb_instant': false, // 'context_steam_keys': false, // }; // class ExtensionResources { // static getURL(pathname) { // return browser.runtime.getURL(pathname); // } // static get(pathname) { // return fetch(ExtensionResources.getURL(pathname)); // } // static getJSON(pathname) { // return ExtensionResources.get(pathname).then(r => r.json()); // } // static getText(pathname) { // return ExtensionResources.get(pathname).then(r => r.text()); // } // } // /** // * DOMPurify setup // * @see https://github.com/cure53/DOMPurify // */ // (async function() { // let allowOpenInNewTab = SyncedStorage.defaults.openinnewtab; // try { // await SyncedStorage; // allowOpenInNewTab = SyncedStorage.get("openinnewtab"); // } catch(e) { // console.error(e); // } // /** // * NOTE FOR ADDON REVIEWER: // * We are modifying default DOMPurify settings to allow other protocols in URLs // * and to allow links to safely open in new tabs. // * // * We took the original Regex and aded chrome-extension://, moz-extension:// and steam:// // * First two are needed for linking local resources from extension, // * steam:// protocol is used by Steam store to open their own client (e.g. when you want to launch a game). // * // * The addition of the `target` attribute to the allowed attributes is done in order to be able to open links in a new tab. // * We only allow target="_blank" while adding rel="noreferrer noopener" to prevent child window to access window.opener // * as described in https://www.jitbit.com/alexblog/256-targetblank---the-most-underestimated-vulnerability-ever/ // */ // let purifyConfig = { // ALLOWED_URI_REGEXP: /^(?:(?:(?:f|ht)tps?|mailto|tel|callto|cid|xmpp|chrome-extension|moz-extension|steam):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i // }; // if (allowOpenInNewTab) { // purifyConfig.ADD_ATTR = ["target"]; // DOMPurify.addHook("uponSanitizeAttribute", (node, data) => { // if (data.attrName === "target") { // if (data.attrValue === "_blank") { // node.setAttribute("rel", "noreferrer noopener"); // } else { // data.keepAttr = false; // } // } // }); // } // DOMPurify.setConfig(purifyConfig); // })(); // class Language { // static getCurrentSteamLanguage() { // if (this._currentSteamLanguage != null) { // return this._currentSteamLanguage; // } // let nodes = document.querySelectorAll("script[src]"); // let re = /(?:\?|&(?:amp;)?)l=([^&]+)/; // for (let n of nodes) { // let src = n.getAttribute("src"); // let match = src.match(re); // if (match) { // this._currentSteamLanguage = match[1]; // return this._currentSteamLanguage; // } // } // // In a Content Context, we can check for a cookie // if (typeof CookieStorage != 'undefined') { // this._currentSteamLanguage = CookieStorage.get("Steam_Language") || null; // } // return this._currentSteamLanguage; // } // static getLanguageCode(language) { // let code = Language.languages[language]; // return code ? code : "en"; // } // static isCurrentLanguageOneOf(array) { // return array.includes(Language.getCurrentSteamLanguage()); // } // } // Language._currentSteamLanguage = null; // Language.languages = { // "english": "en", // "bulgarian": "bg", // "czech": "cs", // "danish": "da", // "dutch": "nl", // "finnish": "fi", // "french": "fr", // "greek": "el", // "german": "de", // "hungarian": "hu", // "italian": "it", // "japanese": "ja", // "koreana": "ko", // "norwegian": "no", // "polish": "pl", // "portuguese": "pt-PT", // "brazilian": "pt-BR", // "russian": "ru", // "romanian": "ro", // "schinese": "zh-CN", // "spanish": "es-ES", // "latam": "es-419", // "swedish": "sv-SE", // "tchinese": "zh-TW", // "thai": "th", // "turkish": "tr", // "ukrainian": "ua", // "vietnamese": "vi", // }; // class Localization { // static loadLocalization(code) { // return ExtensionResources.getJSON(`/localization/${code}/strings.json`); // } // static init() { // if (Localization._promise) { return Localization._promise; } // let currentSteamLanguage = Language.getCurrentSteamLanguage(); // let storedSteamLanguage = SyncedStorage.get("language"); // if (currentSteamLanguage === null) { // currentSteamLanguage = storedSteamLanguage; // } else { // if (currentSteamLanguage !== storedSteamLanguage) { // storedSteamLanguage = currentSteamLanguage; // SyncedStorage.set("language", currentSteamLanguage); // Background.action("clearpurchases"); // } // } // function deepAssign(target, source) { // // Object.assign() but deep-assigning objects recursively // for (let [key, val] of Object.entries(source)) { // if (target[key] === undefined) { // console.warn("The key %s doesn't exist in the English localization file", key); // continue; // } // if (typeof val === "object") { // deepAssign(target[key], val); // } else if (val !== "") { // target[key] = val; // } // } // return target; // } // let local = Language.getLanguageCode(currentSteamLanguage); // let codes = ["en",]; // if (local !== null && local !== "en") { // codes.push(local); // } // Localization._promise = Promise.all( // codes.map(lc => Localization.loadLocalization(lc)) // ).then(function([english, local]) { // Localization.str = english; // if (local) { // deepAssign(Localization.str, local); // } // return Localization.str; // }); // return Localization._promise; // } // static then(onDone, onCatch) { // return Localization.init().then(onDone, onCatch); // } // static getString(key) { // // Source: http://stackoverflow.com/a/24221895 // let path = key.split('.').reverse(); // let current = Localization.str; // while (path.length) { // if (typeof current !== 'object') { // return undefined; // } else { // current = current[path.pop()]; // } // } // return current; // } // } // Localization._promise = null; // Localization.init(); addNewScript('g_conf_Script', '\ \n\ var gc_multiLanguage = null;\n\ \n\ var g_conf = [\n\ {steamID: ""\n\ ,language: "auto_detected" /*语言: 自动检测*/\n\ ,delay: 4 /*设置你的留言时间间隔,单位秒*/\n\ ,strNoOperate: "(不留言)" /*设置你的不留言的标识符: 如果不需要留言,则需在备注中添加这个不留言的标识符*/\n\ ,strRemarkPlaceholder: "{name}" /*设置你的称呼占位符: 同上*/\n\ \n\ ,autoLogin: 1 /*没有登录时是否自动跳转到登录页面 (点击确定跳转,点击关闭不跳转)*/\n\ ,is_Debug: true /*是否是调试模式(总开关,是否显示调试输出,显示当前运行状态)*/\n\ ,isTrackRunStatus: true /*是否跟踪运行状态(更详细的调试输出,可控型只显示错误警告 到 变量级)*/\n\ ,isAddYunBreakWarn: true /*是否添加运行中断警告*/\n\ \n\ ,YunStatus: false /*当前运行状态(比如正在留言中之类的就是正在运行)*/\n\ ,isTranslationText: false /*是否进行了翻译*/\n\ \n\ ,isWarnInfo: false /*是否出现警告信息(如果没有则不需要清空)*/\n\ ,isCommentRunStatus: false /*是否正在留言*/\n\ ,isNationalityRunStatus: false /*是否正在设置国籍*/\n\ ,isNoCommentRunStatus: false /*是否正在设置不留言*/\n\ ,isTimeIntervalRunStatus: false /*是否正在设置留言时间间隔*/\n\ ,isAutoCommentRunStatus: false /*是否正在设置自动留言计划*/\n\ ,isFriendToGroupRunStatus: false /*是否正在设置好友分组*/\n\ }\n\ ];/* g_conf[0].*/\n\ \n\ \n\ const g_default_configuration = {\n\ steamID: ""\n\ ,language: "auto_detected" /*语言: 自动检测*/\n\ ,delay: 4 /*设置你的留言时间间隔,单位秒*/\n\ ,strNoOperate: "(不留言)" /*设置你的不留言的标识符: 如果不需要留言,则需在备注中添加这个不留言的标识符*/\n\ ,strRemarkPlaceholder: "{name}" /*设置你的称呼占位符: 同上*/\n\ ,autoLogin: 1 /*没有登录时是否自动跳转到登录页面 (点击确定跳转,点击关闭不跳转)*/\n\ ,isShowQuickNavigationBar: false /*是否显示快速导航栏*/\n\ };\n\ \n\ \n\ const g_debug_info = [\n\ {\n\ language: "简体中文"\n\ },\n\ {\n\ language: "English"\n\ }\n\ ];\n\ \n\ /*ui配置相关信息*/\n\ \n\ var g_uiConf = {\n\ isShowQuickNavigationBar: false /*是否显示快速导航栏*/\n\ ,isShow_menu_friend: true /*好友列表*/\n\ ,isShow_menu_activity: true /*动态列表*/\n\ ,isShow_menu_registerKey: true /*激活key*/\n\ ,isShow_menu_redeemWalletCode: true /*充值key*/\n\ ,isShow_menu_steamdbFree: true /*SteamDB预告*/\n\ };/* g_uiConf.*/\n\ \n\ '); /** * common.js */ //------------------------------------------------------------------------------------------------------------- /** * @summary 使线程进入休眠模式 * @async * @param {UINT} ms 毫秒数 * @example * await sleep(1000); //使当前线程等待1s后继续执行 */ function sleep(ms) { return new Promise(resolve => setTimeout(resolve, ms)); } /** * @summary 判断页面是移动端还是pc端 * @return {Boolean} 如果是移动端返回true, 如果是pc端返回false */ function opinion() { if ((navigator.userAgent.match( /(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i ))) { return true; //移动端 } else { return false; //pc端 } } /** * @summary 判断是否是非负整数 * @param {int} val 待判断的整数 * @return {Boolean} 是则返回true,否则返回false */ function isIntNum(val){ // var regPos = /^\d+$/; // 非负整数 if(regPos.test(val)){ return true; }else{ return false; } } /** * @summary 解析JSON字符串 * @param {String} jsonText JSON字符串 * @return {Object} JSON对象 */ function JSON_processing_parsing_JsObj(jsonText){ // var JSON_jsObj; if (jsonText == "") return; //console.log("待处理数据:"); //console.log(jsonText); JSON_jsObj = JSON.parse(jsonText); console.log("解析后数据:"); console.log(JSON_jsObj); return JSON_jsObj; } /** * @summary 添加新的CSS样式 * @param {String} id 新的<style>标签id, 可用于修改和删除等 * @param {String} newStyle 待添加的CSS样式字符串 */ function addNewStyle(id, newStyle) { var styleElement = document.getElementById(id); if (!styleElement) { styleElement = document.createElement('style'); styleElement.type = 'text/css'; styleElement.id = id; document.getElementsByTagName('head')[0].appendChild(styleElement); } styleElement.appendChild(document.createTextNode(newStyle)); } /** * @summary 添加新的JS脚本 * @param {String} id 新的<script>标签id, 可用于修改和删除等 * @param {String} newScript 待添加的JS脚本字符串 */ function addNewScript(id, newScript) { var styleElement = document.getElementById(id); if (!styleElement) { styleElement = document.createElement('script'); styleElement.type = 'text/javascript'; styleElement.id = id; document.getElementsByTagName('head')[0].appendChild(styleElement); } styleElement.appendChild(document.createTextNode(newScript)); } /** * @summary 添加新的JS脚本(拓展) * @param {String} id 新的<script>标签id, 可用于修改和删除等 * @param {String} newScript 待添加的JS脚本字符串 * @param {String} mode 添加模式(一般来说是<script>标签的格外标识符, 目前有 "async" 和 "defer" ) */ function addNewScriptEx(id, newScript,mode) { var styleElement = document.getElementById(id); if (!styleElement) { styleElement = document.createElement('script'); styleElement.type = 'text/javascript'; styleElement.id = id; if(mode == "async"){ styleElement.setAttribute('async'); }else if(mode == "defer"){ styleElement.setAttribute('defer'); } document.getElementsByTagName('head')[0].appendChild(styleElement); } styleElement.appendChild(document.createTextNode(newScript)); } /** * @summary 添加新的JS模块(实验) * @param {String} id 新的<script>标签id, 可用于修改和删除等 * @param {String} newScript */ function addNewModule(id, newScript){ var styleElement = document.getElementById(id); if (!styleElement) { styleElement = document.createElement('script'); styleElement.type = 'module'; styleElement.id = id; document.getElementsByTagName('head')[0].appendChild(styleElement); } styleElement.appendChild(document.createTextNode(newScript)); } /** * 动态加载一个js/css文件, 位于<head>标签最后面新的<script>标签里, 通过src引入指定的url * @summary 动态加载一个js/css文件 * @param {String} filePath 文件路径 * @param {String} filetype 文件类型 */ function loadjscssFile(filePath, filetype) { if (filetype == "js") { var fileref = document.createElement('script') fileref.setAttribute("type", "text/javascript") fileref.setAttribute("src", filePath) } else if (filetype == "css") { var fileref = document.createElement("link") fileref.setAttribute("rel", "stylesheet") fileref.setAttribute("type", "text/css") fileref.setAttribute("href", filePath) } if (typeof fileref != "undefined") { document.getElementsByTagName("head")[0].appendChild(fileref); //向元素添加新的子节点,作为最后一个子节点 } } /** * 动态加载一个js/css文件(此方法可以添加id和media类型), 位于<head>标签最后面新的<script>标签里, 通过src引入指定的url * @summary 动态加载一个js/css文件(拓展) * @param {String} filePath 文件路径 * @param {String} id 节点id * @param {String} filetype 文件类型 */ function loadjscssFile_media(filePath,id, filetype) { //动态加载一个js/css文件 if (filetype == "js") { var fileref = document.createElement('script') fileref.setAttribute("type", "text/javascript") fileref.setAttribute("src", filePath) } else if (filetype == "css") { var fileref = document.createElement("link") if(id != "" || id != null || id != undefined){ fileref.setAttribute("id", id) } fileref.setAttribute("rel", "stylesheet") fileref.setAttribute("type", "text/css") fileref.setAttribute("href", filePath) fileref.setAttribute("media", "all") } if (typeof fileref != "undefined") { document.getElementsByTagName("head")[0].appendChild(fileref); //向元素添加新的子节点,作为最后一个子节点 } } /** * 获取URL对应的资源数据(伪同步, 会阻塞当前线程, 配合 async 和 await 使用) * @summary 获取URL对应的资源数据 * @async * @param {String} resourceURL 资源url * @param {Boolean} retDataMode 返回的数据方式 * @return {String} 返回获取到的数据 */ async function getResourceByURL(resourceURL,retDataMode){ var retData = null; var waitStatus = true; GM_xmlhttpRequest({ method: 'GET', url: resourceURL, headers: { 'User-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.122 Safari/537.36', //'Accept': 'application/atom+xml,application/xml,text/xml', //"Content-Type": "application/x-www-form-urlencoded", }, onload: function(response) { if (response.status === 200) { console.log('getResourceByURL()请求成功!'); if(retDataMode == true) retData = response.responseText; else retData = response; waitStatus = false; //不等待 } else { console.log('getResourceByURL()请求失败! 状态码:' + response.status); //console.log(response); //console.log(response.responseText); } }, onerror: function(err) { console.log('getResourceByURL()请求错误!', err); //waitStatus = false; //不等待 }, onabort: function(err) { console.log('getResourceByURL()请求被中止!', err); //waitStatus = false; //不等待 }, ontimeout: function(err) { console.log('getResourceByURL()请求超时!', err); //waitStatus = false; //不等待 } }); while (waitStatus){ //强制等待异步函数执行完毕后再执行 console.log("wait..."); await sleep(100); //延迟0.1秒 } //console.log(retData); return retData; } async function getResourceByURL_UsabilitTest(resourceURLs,retDataMode,timeouts){ var retData = null; var waitStatus = true; GM_xmlhttpRequest({ method: 'GET', url: resourceURL, headers: { 'User-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.122 Safari/537.36', //'Accept': 'application/atom+xml,application/xml,text/xml', //"Content-Type": "application/x-www-form-urlencoded", }, timeout: timeouts, onload: function(response) { if (response.status === 200) { console.log('getResourceByURL()请求成功!'); if(retDataMode == true) retData = response.responseText; else retData = response; waitStatus = false; //不等待 } else { console.log('getResourceByURL()请求失败! 状态码:' + response.status); //console.log(response); //console.log(response.responseText); } }, onerror: function(err) { console.log('getResourceByURL()请求错误!', err); //waitStatus = false; //不等待 }, onabort: function(err) { console.log('getResourceByURL()请求被中止!', err); //waitStatus = false; //不等待 }, ontimeout: function(err) { console.log('getResourceByURL()请求超时!', err); //waitStatus = false; //不等待 }, }); while (waitStatus){ //强制等待异步函数执行完毕后再执行 console.log("wait..."); await sleep(100); //延迟0.1秒 } //console.log(retData); return retData; } /** * @async * @param {String} resourceURL 资源url */ async function getResourceByURL_original(resourceURL) { var retData; var waitStatus = true; jQuery.ajax({ type: "Get", //请求方式 //async: false, //contentType: "application/json;charset=UTF-8",//请求的媒体类型 url: resourceURL, //请求地址 // headers: { // 'User-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.122 Safari/537.36', // //'Accept': 'application/atom+xml,application/xml,text/xml', // //"Content-Type": "application/x-www-form-urlencoded", // }, //data: JSON.stringify(list), //数据,json字符串 success: function(result) { //请求成功 retData = result; console.log("请求成功了!",retData); //let nIstart = Data.indexOf('StartTradeOffer('); //let nIend = Data.indexOf(');', nIstart); //let AccountID = Data.slice(nIstart + 'StartTradeOffer('.length + 1, nIend - 1); //nIstart = Data.indexOf('"steamid":"'); //nIend = Data.indexOf('",', nIstart); //let profileID = Data.slice(nIstart + '"steamid":"'.length, nIend); //console.log("getgetProfilesID() i:", i, "AccountID:", AccountID, "profileID:", profileID); // for (let i = 0; i < waitStatus1.length; i++) { // if (waitStatus1[i][0] == profileID) //是否是同一个用户 // { // if (waitStatus1[i][1] == false) //这个用户是否已经获取过了(测试多个相同用户信息的获取) // continue; // waitStatus1[i][1] = false; // //returnData1.push(AccountID); //存储数据 // returnData1[i] = AccountID; //存储数据到对应的位置(受网络影响,响应顺序可能会不同) // //console.log("getgetProfilesID() 成功存储数据 AccountID:",AccountID); // return; // //console.log("waitStatus1[i][1] break",i,waitStatus1[i][1]); // } // } // console.log("getgetProfilesID 数据错误!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"); // console.log("waitStatus1:", waitStatus1, 'returnData1:', returnData1); // console.log('profileID:', profileID, 'AccountID:', AccountID); return; //console.log("DBG!",nIstart,nIend); }, error: function(e) { //请求失败,包含具体的错误信息 console.log("请求失败了!", e.status); console.log("请求失败了!", e.responseText); } }); //console.log("getgetProfilesID() i:",i,"waitStatus1:",waitStatus1); while (waitStatus){ //强制等待异步函数执行完毕后再执行 console.log("wait..."); await sleep(50); //延迟0.1秒 } //console.log("waitStatus1[i][1]:",waitStatus1[i][1],"returnData1[i]:",returnData1[i]); return retData; // jQuery.get(URL, { // // "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9", // // // "Content-Type": "application/x-www-form-urlencoded", //非常重要 // // "Accept-Encoding": "gzip, deflate, br", // // "Accept-Language": "zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2", // // "Cache-Control": "max-age=0", // // "Connection": "keep-alive", // // "Cookie": "sessionid=6f84a0f48cddb56ad66394b6; steamCountry=HK%7Cda7daa2682f7a361e594f8dad55fe9df; timezoneOffset=28800,0", // // "Host": "steamcommunity.com", // // "Upgrade-Insecure-Requests": "1", // 'User-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.122 Safari/537.36', // }, function(response) { // if (response.status === 200) { // console.log("获取失败!",response.responseText); // } else { // console.log("获取成功!",response.responseText); // } // }).fail(function() { // console.log("无法获取!"); // }).always(function() { // //console.log("当前处理了 " + (i + 1) + "个, 总计 " + total + " 个好友."); // }); } //------------------------------------------------------------------------------------------------------------- function WriteLog() { // eslint-disable-next-line no-console console.log('%c[SteamDB]%c', 'color:#2196F3; font-weight:bold;', '', ...arguments); } //console.log("%c百度2020校园招聘简历提交:http://dwz.cn/XpoFdepe", "color:red")) //color:#00a1d6 //------------------------------------------------------------------------------------------------------------- class Arguments { static getArgumentsAllValue(argumentsObj) { //解析函数的参数并进行合并为字符串 let str = ""; for (let i = 0; i < argumentsObj.length; i++) { str += argumentsObj[i] + " "; } return str; } static getArgumentsAllValue_noFunction(argumentsObj) { //解析函数的参数并进行合并为字符串 let str = ""; for (let i = 0; i < argumentsObj.length; i++) { if (typeof argumentsObj[i] == 'function') { //如果是函数则跳过 continue; } str += argumentsObj[i] + " "; } return str; } static getArgumentsAllValueByDebug(argumentsObj) { //解析函数的参数并进行合并为字符串 //返回数组[track,str] let str = ""; let track = ""; console.log(arguments); //console.log(arguments.callee.name); for (let i = 0; i < argumentsObj.length; i++) { if (typeof argumentsObj[i] == 'number') { //如果是数字则转为字符串 //argumentsObj[i] = argumentsObj[i].toString(); str += argumentsObj[i] + " "; continue; } let s = argumentsObj[i].match(/\s*[A-Za-z\$\_][A-Za-z\$\_\.0-9]+\s*\(/); if (s != null) { if (null != s[0]) { //提取出' 函数名 ('这样的字符串 track = s[0].slice(0, -1); //去掉最后的(,得到函数名 let s1 = argumentsObj[i].replace(/\s*[A-Za-z\$\_][A-Za-z\$\_\.0-9]+\s*\(/, ""); //从字符串中删除函数名,然后剩下的部分 str += s1.slice(1, s1.length) + " "; //去掉最前面的),得到提示信息 continue; } } str += argumentsObj[i] + " "; } return [track, str]; } } //------------------------------------------------------------------------------------------------------------- /** * @class * @classdesc 用于输出和记录调试信息的类 * */ class Log { /** * @constructs 构造方法(模块名称,调试状态) //默认开启调试 * @param {String} moduleName 模块名称 (当输出调试信息时会在最前面显示出来) * @param {Boolean} debugStatus 调试状态 */ constructor(moduleName, debugStatus = true) { this.m_moduleNamel = moduleName; //设置模块名称 this.arrlogContent = []; //日志内容(数组) g_conf[0].is_Debug = debugStatus; //设置调试状态 } /** * @param {Boolean} debugStatus 调试状态 */ setDebugStatus(debugStatus = true) { g_conf[0].is_Debug = debugStatus; } /** * 清除控制台输出 */ clear() { console.clear(); } /** * @param {String} mode 释放资源模式 */ release(mode){ this.arrlogContent = []; } /** * 用于对此类进行测试 * @param {Object} strTestInfo 需要进行测试输出的字符串 */ test(strTestInfo) { //用于对Log类进行输出测试 if (strTestInfo == undefined) strTestInfo = "默认测试内容"; log.out("模块名称:", this.m_moduleNamel); log.out("是否开启调试:", g_conf[0].is_Debug); log.debug(strTestInfo); log.info(strTestInfo); log.warn(strTestInfo); log.error(strTestInfo); log.fatal(strTestInfo); } /** * @param {Object} strLog 需要直接输出的字符串 */ out(strLog) { console.log('%c[' + this.m_moduleNamel + ' out]%c' + Arguments.getArgumentsAllValue(arguments), 'color:#000000; font-weight:bold;', 'color:#000000;'); } /** * 输出Debug等级的日志信息 * @param {String} $funcName 需要输出的函数名称 * @param {String} $strDebugInfo 需要输出的字符串 */ //伪重载实现,两种版本 //log.debug("getArgumentsAllValueByDebug() 111"); //log.debug(getArgumentsAllValueByDebug,"111"); debug($funcName, $strDebugInfo) { //var This = this; //debugger; let fontStyle = 'font-family:-apple-system,BlinkMacSystemFont,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei","Helvetica Neue",Helvetica,Arial,sans-serif;'; let titleStyle = 'padding: 2px 6px; border-radius: 3px 0 0 3px; background: #606060;color: #fff;' + fontStyle; let contentStyle = 'padding: 2px 6px; border-radius: 0 3px 3px 0; background: #1475b2;color: #fff;' + fontStyle; let arr; if (typeof $funcName == 'function') { // if (g_conf[0].is_Debug) { //debugger; console.log($funcName); $funcName = '.' + $funcName.name; arr = Arguments.getArgumentsAllValue_noFunction(arguments); console.log('%c[' + this.m_moduleNamel + ' Debug-B]%c' + $funcName + '%c' + arr, 'color:#2196F3; font-weight:bold;', titleStyle, contentStyle); } } else { if (g_conf[0].is_Debug) { arr = Arguments.getArgumentsAllValueByDebug(arguments); console.log('%c[' + this.m_moduleNamel + ' Debug-A]%c' + arr[0] + '%c' + arr[1], 'color:#2196F3; font-weight:bold;', titleStyle, contentStyle); } } } /** * 输出Info等级的日志信息 * @param {String} $funcName 需要输出的函数名称 * @param {String} $strDebugInfo 需要输出的字符串 */ info($strLogInfo) { if (g_conf[0].is_Debug) { let fontStyle = 'font-family:-apple-system,BlinkMacSystemFont,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei","Helvetica Neue",Helvetica,Arial,sans-serif;'; let titleStyle = 'padding: 2px 6px; border-radius: 3px 0 0 3px; background: #606060;color: #fff;' + fontStyle; let contentStyle = 'padding: 2px 6px; border-radius: 0 3px 3px 0; background: #42c02e;color: #fff;' + fontStyle; let arr = Arguments.getArgumentsAllValueByDebug(arguments); console.log('%c[' + this.m_moduleNamel + ' Info]%c' + arr[0] + '%c' + arr[1], 'color:#00edc3; font-weight:bold;', titleStyle, contentStyle); } } /** * 输出Warn等级的日志信息 * @param {String} $funcName 需要输出的函数名称 * @param {String} $strDebugInfo 需要输出的字符串 */ warn($strWarnInfo) { if (g_conf[0].is_Debug) { let fontStyle = 'font-family:-apple-system,BlinkMacSystemFont,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei","Helvetica Neue",Helvetica,Arial,sans-serif;'; let titleStyle = 'padding: 2px 6px; border-radius: 3px 0 0 3px; background: #606060;color: #fff;' + fontStyle; let contentStyle = 'padding: 2px 6px; border-radius: 0 3px 3px 0; background: #ff7800;color: #fff;' + fontStyle; let arr = Arguments.getArgumentsAllValueByDebug(arguments); console.log('%c[' + this.m_moduleNamel + ' Warn]%c' + arr[0] + '%c' + arr[1], 'color:#ffa800; font-weight:bold;', titleStyle, contentStyle); } } /** * 输出Error等级的日志信息 * @param {String} $funcName 需要输出的函数名称 * @param {String} $strDebugInfo 需要输出的字符串 */ error($strErrInfo) { if (g_conf[0].is_Debug) { let fontStyle = 'font-family:-apple-system,BlinkMacSystemFont,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei","Helvetica Neue",Helvetica,Arial,sans-serif;'; let titleStyle = 'padding: 2px 6px; border-radius: 3px 0 0 3px; background: #606060;color: #fff;' + fontStyle; let contentStyle = 'padding: 2px 6px; border-radius: 0 3px 3px 0; background: #ff00a2;color: #fff;' + fontStyle; let arr = Arguments.getArgumentsAllValueByDebug(arguments); console.trace('%c[' + this.m_moduleNamel + ' Error]%c' + arr[0] + '%c' + arr[1], 'color:#ff00c0; font-weight:bold;', titleStyle, contentStyle); } } /** * 输出Fatal等级的日志信息 * @param {String} $funcName 需要输出的函数名称 * @param {String} $strDebugInfo 需要输出的字符串 */ fatal($strFatalInfo) { if (g_conf[0].is_Debug) { let fontStyle = 'font-family:-apple-system,BlinkMacSystemFont,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei","Helvetica Neue",Helvetica,Arial,sans-serif;'; let titleStyle = 'padding: 2px 6px; border-radius: 0 3px 3px 0; background: #606060;color: #fff;' + fontStyle; let contentStyle = 'padding: 2px 6px; border-radius: 0 3px 3px 0; background: #ff5252;color: #fff;' + fontStyle; let arr = Arguments.getArgumentsAllValueByDebug(arguments); console.trace('%c[' + this.m_moduleNamel + ' Fatal]%c' + arr[0] + '%c' + arr[1], 'color:#ff0000; font-weight:bold;', titleStyle, contentStyle); } } } var log = new Log("Main"); log.info("Test"); //log.test("Arguments.getArgumentsAllValueByDebug() successed!"); //log.debug("Arguments.getArgumentsAllValueByDebug() 111"); //log.debug(Arguments.getArgumentsAllValueByDebug, "111"); // /** // */ // function getRuntimeEnviInfo(){ // var naObj = window.navigator; // document.write("浏览器的信息如下: <hr>"); // for (var i in naObj) { // console.log(i + " : <span style='color:blue;'>" + typeof naObj[i] + '</span><br><span style=\'color:red;\'>' + naObj[i] + "</span><br>"); // } // /** // */ // function getRuntimeEnviInfo(){ // var naObj = window.navigator; // document.write("浏览器的信息如下: <hr>"); // for (var i in naObj) { // document.write(i + " : <span style='color:blue;'>" + typeof naObj[i] + '</span><br><span style=\'color:red;\'>' + naObj[i] + "</span><br>"); // } // function openWin(url,name,width,height){ // var str = 'width=' + width + ',height=' + height; // return window.open(url,name,str); // } // function closeWin(winObj){ // return winObj.close(); // } // } // var textNode = '<div style="z-index: 999;position: relative;"><a href="https://www.baidu.com/" target="newWin">百度</a><button id="open">打开窗口</button><button id="close">关闭窗口</button></div>'; // function createNode(template){ // var start = Date.now(); // //var tempNode = document.createElement('div'); // //tempNode.innerHTML = template; // //var node = tempNode; // var node = document.createRange().createContextualFragment(textNode); // console.log(Date.now() - start); // return node; // } // document.getElementsByTagName('body')[0].appendChild(createNode(textNode)); // document.getElementById('open').onclick = ()=>{ // openWin('','newWin',320,240); // }; // document.getElementById('close').onclick = ()=>{ // closeWin(newWin); // }; /** * 通知类 * https://developer.mozilla.org/zh-CN/docs/Web/API/notification/Using_Web_Notifications */ class Notifications{ constructor(arg) { this.enabled = true; //是否启用通知 this.defaultWaitTime = 2000; //通知默认等待时间 (x秒后关闭通知) } init(){ // 检查浏览器是否支持通知 if (!("Notification" in window)) { console.log("此浏览器不支持桌面通知!"); } // 检查是否已经授予通知权限 else if (Notification.permission === "granted") { // 如果用户已经同意了通知权限 var notification = new Notification("通知已启用."); return true; } // 否则,需要请求用户的许可 else if (Notification.permission !== 'denied' || Notification.permission === "default") { Notification.requestPermission(function (permission) { // 如果用户许可了,则创建一个通知进行测试 if (permission === "granted") { var notification = new Notification("通知已启用."); return true; } }); } return false; } /** * 输出一条通知 * @param {String} strNotifications */ show(strNotifications){ if(this.enabled){ var notification = new Notification(strNotifications); } } /** * 设置通知状态 * @param {Boolean} notificationsStatus 通知状态 */ setNotificationsStatus(notificationsStatus = true){ this.enabled = notificationsStatus; } /** * 设置默认等待时间 * @param {Number} defaultWaitTime 通知默认等待时间 (x秒后关闭通知) */ setNotificationsDefaultWaitTime(defaultWaitTime = 2000){ this.defaultWaitTime = defaultWaitTime; } } /** * resource.js */ class resource { constructor(arg) { } async init(type){ if(type) //第一次加载才需要加载资源 await this._loadResource(type); //加载资源 } async _loadResource(type){ //加载资源 if(type) //第一次加载才需要加载基础资源 await this._loadBaseResources(); //加载基础资源 } async _loadBaseResources(){ //加载基础资源 let arr = []; var arrjsData = new Array(5); arr.push(new Promise(async function (resolve, reject){ if(document.readyState == "loading"){ document.addEventListener("DOMContentLoaded", function(event) { //console.log("DOM fully loaded and parsed"); // if(gc_menu_friends_ui.loadProgress < 9) //资源是否已经加载完毕(已缓存),如果加载完成则不需要显示加载UI // { // gc_menu_friends_ui.showLoadUI(); // gc_menu_friends_ui.loadTextChange(true); //改变当前加载进度 // gc_menu_friends_ui.isDomLoaded = true; // } resolve('DOM fully loaded') // 数据处理完成 // reject('失败') // 数据处理出错 }); } else{ //document.readyState == "interactive" || document.readyState == "complete" resolve('DOM advance loaded(possible)') // 数据处理完成 } })); debugger var resList = getResConfByID("BaseResources"); //通过资源id获取对应的资源列表, 返回资源列表数组 resInfo for (let i = 0; i < resList.length; i++) { //遍历所有的资源 var resChildList = resList[i].res; for (let j = 0; j < resChildList.length; j++) { //遍历每个资源的res if(resChildList[j].isFight == true){ } else{ switch (resChildList[j].resMode){ case _RESMODE.res_Tampermonkey: arr.push(new Promise(async function (resolve, reject){ var resData = GM_getResourceText(resChildList[j].sourceInfo[0]); if(_RESTYPE.res_css == resChildList[j].resType){ if(resChildList[j].onSucceed != null && typeof(resChildList[j].onSucceed) === 'function') resData = resChildList[j].onSucceed(resData); addNewStyle(resList[i].resName, resData); } else if(_RESTYPE.res_js == resChildList[j].resType){ if(resChildList[j].onSucceed != null && typeof(resChildList[j].onSucceed) === 'function') resData = resChildList[j].onSucceed(resData); addNewScript(resList[i].resName, resData); } resolve(resList[i].resName) // 数据处理完成 // reject('失败') // 数据处理出错 })); break; case _RESMODE.res_CDN: arr.push(new Promise(async function (resolve, reject){ let URLs = resChildList[j].sourceInfo; var resData; for (let i = 0; i < URLs.length; i++) { //loadjscssFile("https://www.layuicdn.com/layui-v2.5.6/layui.all.js","js"); resData = await getResourceByURL(URLs[i],true); // } //console.log("数据获取成果",resData); if(_RESTYPE.res_css == resChildList[j].resType){ if(resChildList[j].onSucceed != null && typeof(resChildList[j].onSucceed) === 'function') resData = resChildList[j].onSucceed(resData); addNewStyle(resList[i].resName, resData); } else if(_RESTYPE.res_js == resChildList[j].resType){ if(resChildList[j].onSucceed != null && typeof(resChildList[j].onSucceed) === 'function') resData = resChildList[j].onSucceed(resData); addNewScript(resList[i].resName, resData); } resolve(resList[i].resName) // 数据处理完成 // reject('失败') // 数据处理出错 })); break; case _RESMODE.res_LocalVariables: arr.push(new Promise(async function (resolve, reject){ if(_RESTYPE.res_css == resChildList[j].resType){ if(resChildList[j].onSucceed != null && typeof(resChildList[j].onSucceed) === 'function') eval(resChildList[j].sourceInfo[0]) = resChildList[j].onSucceed( eval(resChildList[j].sourceInfo[0]) ); addNewStyle(resList[i].resName, eval(resChildList[j].sourceInfo[0])); } else if(_RESTYPE.res_js == resChildList[j].resType){ if(resChildList[j].onSucceed != null && typeof(resChildList[j].onSucceed) === 'function') eval(resChildList[j].sourceInfo[0]) = resChildList[j].onSucceed( eval(resChildList[j].sourceInfo[0]) ); addNewScript(resList[i].resName, eval(resChildList[j].sourceInfo[0])); } resolve(resList[i].resName) // 数据处理完成 // reject('失败') // 数据处理出错 })); break; default: break; } } } } // arr.push(new Promise(async function (resolve, reject){ // // //var cssData = await getResourceByURL("https://www.layuicdn.com/layui-v2.5.6/css/layui.css",true); // // //addNewStyle('layui_style',cssData); // // loadjscssFile_media("https://www.layuicdn.com/layui-v2.5.6/css/layui.css",null, "css"); // let css = GM_getResourceText('css_layui'); // addNewStyle('css_layui',css); // resolve('css_layui') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // // loadjscssFile_media("https://www.layuicdn.com/layui-v2.5.6/css/modules/laydate/default/laydate.css?v=5.0.9", "layuicss-laydate", "css"); // let css = GM_getResourceText('css_laydate'); // addNewStyle('css_laydate',css); // resolve('css_laydate') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // // loadjscssFile_media("https://www.layuicdn.com/layui-v2.5.6/css/modules/layer/default/layer.css?v=3.1.1", "layuicss-layer", "css"); // let css = GM_getResourceText('css_layer'); // addNewStyle('css_layer',css); // resolve('css_layer') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // // loadjscssFile_media("https://www.layuicdn.com/layui-v2.5.6/css/modules/code.css", "layuicss-skincodecss", "css"); // let css = GM_getResourceText('css_layui_Modules'); // addNewStyle('css_layui_Modules',css); // resolve('css_layui_Modules') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // // //font-awesome // // loadjscssFile("https://cdn.bootcss.com/font-awesome/4.7.0/css/font-awesome.min.css", "css"); // let css = GM_getResourceText('css_fontAwesome'); // addNewStyle('css_fontAwesome',css); // resolve('css_fontAwesome') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); //0.基本环境-加载css arr.push(new Promise(function (resolve, reject){ addNewStyle('styles_js1', "/*layui.css*/\ @font-face {\ font-family: layui-icon;\ src: url(https://www.layuicdn.com/layui-v2.5.6/font/iconfont.eot?v=256);\ src: url(https://www.layuicdn.com/layui-v2.5.6/font/iconfont.eot?v=256#iefix) format('embedded-opentype'),url(https://www.layuicdn.com/layui-v2.5.6/font/iconfont.woff2?v=256) format('woff2'),url(https://www.layuicdn.com/layui-v2.5.6/font/iconfont.woff?v=256) format('woff'),url(https://www.layuicdn.com/layui-v2.5.6/font/iconfont.ttf?v=256) format('truetype'),url(https://www.layuicdn.com/layui-v2.5.6/font/iconfont.svg?v=256#layui-icon) format('svg')\ }\ /*layer.css?v=3.1.1*/\ .layui-layer-load {\ background: url(https://www.layuicdn.com/layui-v2.5.6/css/modules/layer/default/loading-1.gif) center center no-repeat #eee\ }\ \ .layui-layer-ico {\ background: url(https://www.layuicdn.com/layui-v2.5.6/css/modules/layer/default/icon.png) no-repeat\ }\ \ .layui-layer-loading .layui-layer-content {\ width: 60px;\ height: 24px;\ background: url(https://www.layuicdn.com/layui-v2.5.6/css/modules/layer/default/loading-0.gif) no-repeat\ }\ \ .layui-layer-loading .layui-layer-loading1 {\ width: 37px;\ height: 37px;\ background: url(https://www.layuicdn.com/layui-v2.5.6/css/modules/layer/default/loading-1.gif) no-repeat\ }\ \ .layui-layer-ico16,.layui-layer-loading .layui-layer-loading2 {\ width: 32px;\ height: 32px;\ background: url(https://www.layuicdn.com/layui-v2.5.6/css/modules/layer/default/loading-2.gif) no-repeat\ }\ \ .layui-layer-iconext {\ background: url(https://www.layuicdn.com/layui-v2.5.6/css/modules/layer/default/icon-ext.png) no-repeat\ }\ /*font-awesome.min.css*/\ @font-face{\ font-family:'FontAwesome';src:url('https://cdn.bootcss.com/font-awesome/4.7.0/fonts/fontawesome-webfont.eot?v=4.7.0');src:url('https://cdn.bootcss.com/font-awesome/4.7.0/fonts/fontawesome-webfont.eot?#iefix&v=4.7.0') format('embedded-opentype'),url('https://cdn.bootcss.com/font-awesome/4.7.0/fonts/fontawesome-webfont.woff2?v=4.7.0') format('woff2'),url('https://cdn.bootcss.com/font-awesome/4.7.0/fonts/fontawesome-webfont.woff?v=4.7.0') format('woff'),url('https://cdn.bootcss.com/font-awesome/4.7.0/fonts/fontawesome-webfont.ttf?v=4.7.0') format('truetype'),url('https://cdn.bootcss.com/font-awesome/4.7.0/fonts/fontawesome-webfont.svg?v=4.7.0#fontawesomeregular') format('svg');font-weight:normal;font-style:normal\ }\ " ); /* 覆盖layui的css字体加载路径,改为在线资源路径而不是相对路径 */ //覆盖layui的css addNewStyle('styles_js0', 'a {\ color:#ebebeb;\ text-decoration: none;\ }\ a:hover {\ color: #aaa\ }\ .layui-form-checkbox[lay-skin=primary] span{\ color: #ebebeb;\ }\ .layui-checkbox-disbaled[lay-skin=primary] span{\ color: #999;\ }\ .layui-tab-brief>.layui-tab-title .layui-this {\ color: #01e0cb;\ }\ ' ); /* 覆盖layui的css样式 */ //gc_menu_friends_ui.loadTextChange(true); //改变当前加载进度 resolve('css') // 数据处理完成 // reject('失败') // 数据处理出错 })); // //1.基本环境-加载js到页面上,方便调试 // arr.push(new Promise(async function (resolve, reject){ // let js = GM_getResourceText('JS_highstock') // addNewScript('JS_highstock',js); // resolve('JS_highstock') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // let js = GM_getResourceText('JS_highstock_exporting') // addNewScript('JS_highstock_exporting',js); // resolve('JS_highstock_exporting') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // let js = GM_getResourceText('JS_highstock_oldie') // addNewScript('JS_highstock_oldie',js); // resolve('JS_highstock_oldie') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // let js = GM_getResourceText('JS_highstock_networkgraph') // addNewScript('JS_highstock_networkgraph',js); // resolve('JS_highstock_networkgraph') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // let js = GM_getResourceText('JS_highstock_zh_CN') // addNewScript('JS_highstock_zh_CN',js); // resolve('JS_highstock_zh_CN') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // let js = GM_getResourceText('JS_layui'); // //对 o.prototype.addcss 打补丁,使其直接return this, 而不是去加载css, css通过脚本欲加载的资源手动添加 // var findStr = 'layui.link(n.dir+"css/"+e,t,o)'; // var index = js.indexOf(findStr); //查找代补丁代码的位置 // var fixJS = js.slice(0,index); //提取 代补丁代码前部分 // fixJS += 'this'; //添加 补丁代码 // fixJS += js.slice(index+findStr.length); //提取 代补丁代码后部分 // addNewScript('JS_layui',fixJS); // resolve('JS_layui') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // let js = GM_getResourceText('JS_localforage'); // addNewScript('JS_localforage',js); // resolve('JS_localforage') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // //loadjscssFile("https://www.layuicdn.com/layui-v2.5.6/layui.all.js","js"); // var jsData = await getResourceByURL("https://www.layuicdn.com/layui-v2.5.6/layui.all.js",true); // // //console.log("数据获取成果",jsData); // addNewScript('layui_Script', jsData); // //console.log("layui_Script success."); // gc_menu_friends_ui.loadTextChange(true); //改变当前加载进度 // resolve('layui') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // //loadjscssFile("https://cdnjs.cloudflare.com/ajax/libs/localforage/1.7.3/localforage.min.js","js"); // var jsData = await getResourceByURL("https://cdnjs.cloudflare.com/ajax/libs/localforage/1.7.3/localforage.min.js",true); // //console.log("数据获取成果",jsData); // addNewScript('localforage_Script', jsData); // //console.log("localforage_Script success."); // gc_menu_friends_ui.loadTextChange(true); //改变当前加载进度 // resolve('localforage') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // //loadjscssFile("https://code.highcharts.com.cn/highstock/highstock.js","js"); // var jsData = await getResourceByURL("https://code.highcharts.com.cn/highstock/highstock.js",true); // //console.log("数据获取成果",jsData); // addNewScript('highstock_Script', jsData); // //console.log("highstock_Script success."); // gc_menu_friends_ui.loadTextChange(true); //改变当前加载进度 // resolve('highstock') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // //loadjscssFile("https://code.highcharts.com.cn/highcharts/modules/exporting.js","js"); // arrjsData[1] = await getResourceByURL("https://code.highcharts.com.cn/highcharts/modules/exporting.js",true); // //console.log("数据获取成果",jsData); // resolve('highcharts exporting') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // //loadjscssFile("https://code.highcharts.com.cn/highcharts/modules/oldie.js","js"); // arrjsData[2] = await getResourceByURL("https://code.highcharts.com.cn/highcharts/modules/oldie.js",true); // //console.log("数据获取成果",jsData); // resolve('highcharts oldie') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // //loadjscssFile("https://code.highcharts.com.cn/highcharts/modules/networkgraph.js","js"); // arrjsData[3] = await getResourceByURL("https://code.highcharts.com.cn/highcharts/modules/networkgraph.js",true); // //console.log("数据获取成果",jsData); // resolve('highcharts networkgraph') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); // arr.push(new Promise(async function (resolve, reject){ // //loadjscssFile("https://code.highcharts.com.cn/highcharts-plugins/highcharts-zh_CN.js","js"); // arrjsData[4] = await getResourceByURL("https://code.highcharts.com.cn/highcharts-plugins/highcharts-zh_CN.js",true); // //console.log("数据获取成果",jsData); // resolve('highcharts zh_CN') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); arr.push(new Promise(async function (resolve, reject){ addNewStyle('styles_js', '::selection {color:#000;background: #35d5ff;}\ #addFriendToGroup,#unaddFriendToGroup,#setTimeInterval,#unsetTimeInterval,#setNoLeave,#unsetNoLeave,#addCustomName,#translationText,#setNationality,#unsetNationality,#NationalityGroup,#NationalitySortGroup,#OfflineTimeGroup,#ShowFriendData {font-family: "Motiva Sans", Sans-serif;font-weight: 300;\ padding: 2px 5px;border:0;outline:0;border-radius: 2px;color: #67c1f5 !important;background: rgba(0, 0, 0, 0.5 );}\ .persona.offline, a.persona.offline, .persona.offline.a {color:#ccc;}\ .persona, a.persona, .persona a, .friend_status_offline, .friend_status_offline div, .friend_status_offline a {color:#ccc;}\ .player_nickname_hint {color:#ccc;}\ #addFriendToGroup:hover,#unaddFriendToGroup:hover,#setTimeInterval:hover,#unsetTimeInterval:hover,#setNoLeave:hover,#unsetNoLeave:hover,#addCustomName:hover,#translationText:hover,#setNationality:hover,#unsetNationality:hover,#NationalityGroup:hover,#NationalitySortGroup:hover,#OfflineTimeGroup:hover,#ShowFriendData:hover {background-color: #0a6aa1;color: #fff !important;cursor: pointer;}' ); /* 选择的文本 */ addNewStyle('styles1_js',fs_css); /* 选择的文本 */ injectJS(); //gc_menu_friends_ui.loadTextChange(true); //改变当前加载进度 resolve('css js') // 数据处理完成 // reject('失败') // 数据处理出错 })); // arr.push(new Promise(async function (resolve, reject){ // addNewStyle('css_jquery_localizationTool',jquery_localizationTool); /* 选择的文本 */ // let js = GM_getResourceText('Jquery_localizationtool'); // addNewScript('js_jquery_localizationTool',js); // //gc_menu_friends_ui.loadTextChange(true); //改变当前加载进度 // resolve('jquery localizationTool') // 数据处理完成 // // reject('失败') // 数据处理出错 // })); let res = await Promise.all(arr); // addNewScript('highcharts_exporting_Script', arrjsData[1]); // //console.log("highcharts_exporting_Script success."); // gc_menu_friends_ui.loadTextChange(true); //改变当前加载进度 // addNewScript('highcharts_oldie_Script', arrjsData[2]); // //console.log("highcharts_oldie_Script success."); // gc_menu_friends_ui.loadTextChange(true); //改变当前加载进度 // addNewScript('highcharts_networkgraph_Script', arrjsData[3]); // //console.log("highcharts_networkgraph_Script success."); // gc_menu_friends_ui.loadTextChange(true); //改变当前加载进度 // addNewScript('highcharts_zh_CN_Script', arrjsData[4]); // //console.log("highcharts_zh_CN_Script success."); // gc_menu_friends_ui.loadTextChange(true); //改变当前加载进度 // if(!gc_menu_friends_ui.remoreLoadUI()){//移除加载UI // console.log("remoreLoadUI() 失败!"); // } console.log("ret:",res); } async _loadDrawResources(){ //加载绘制资源 let arr = []; var arrjsData = new Array(5); arr.push(new Promise(async function (resolve, reject){ let js = GM_getResourceText('JS_draw'); addNewScript('JS_draw',js); resolve('JS_draw') // 数据处理完成 // reject('失败') // 数据处理出错 })); arr.push(new Promise(async function (resolve, reject){ let js = GM_getResourceText('JS_animate'); addNewScript('JS_animate',js); resolve('JS_animate') // 数据处理完成 // reject('失败') // 数据处理出错 })); arr.push(new Promise(async function (resolve, reject){ let js = GM_getResourceText('JS_sound'); addNewScript('JS_sound',js); resolve('JS_sound') // 数据处理完成 // reject('失败') // 数据处理出错 })); arr.push(new Promise(async function (resolve, reject){ let js = GM_getResourceText('JS_render'); addNewScript('JS_render',js); resolve('JS_render') // 数据处理完成 // reject('失败') // 数据处理出错 })); arr.push(new Promise(async function (resolve, reject){ let js = GM_getResourceText('JS_multithreading'); addNewScript('JS_multithreading',js); resolve('JS_multithreading') // 数据处理完成 // reject('失败') // 数据处理出错 })); let res = await Promise.all(arr); console.log("ret:",res); } } var fs_css = '\ .fs-wrap {\n\ position: relative;\n\ display: inline-block;\n\ vertical-align: bottom;\n\ width: 200px;\n\ margin: 3px;\n\ font-size: 12px;\n\ line-height: 1\n\ }\n\ \n\ .fs-label-wrap {\n\ position: relative;\n\ border: 1px solid #34DEFF;\n\ cursor: default;\n\ color: #66ccff;\n\ border-radius: 4px;\n\ box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075)\n\ }\n\ \n\ .fs-label-wrap,\n\ .fs-dropdown {\n\ -webkit-user-select: none;\n\ -moz-user-select: none;\n\ -ms-user-select: none;\n\ user-select: none\n\ }\n\ \n\ .fs-label-wrap .fs-label {\n\ padding: 4px 22px 4px 8px;\n\ text-overflow: ellipsis;\n\ white-space: nowrap;\n\ overflow: hidden;\n\ cursor: pointer\n\ }\n\ \n\ .fs-arrow {\n\ width: 0;\n\ height: 0;\n\ border-left: 4px solid transparent;\n\ border-right: 4px solid transparent;\n\ border-top: 6px solid #fff;\n\ position: absolute;\n\ top: 0;\n\ right: 4px;\n\ bottom: 0;\n\ margin: auto;\n\ cursor: pointer\n\ }\n\ \n\ .fs-dropdown {\n\ position: absolute;\n\ background-color: #3E9AC6;\n\ border: 1px solid #000;\n\ width: 100%;\n\ z-index: 1000;\n\ border-radius: 4px\n\ }\n\ \n\ .fs-dropdown .fs-options {\n\ max-height: 200px;\n\ overflow: auto\n\ }\n\ \n\ .fs-search input {\n\ width: 90%;\n\ padding: 2px 4px;\n\ border: 0\n\ outline: 0;\n\ }\n\ \n\ .fs-selectAll {\n\ float: right;\n\ cursor: pointer;\n\ margin-top: 4px;\n\ height: auto\n\ }\n\ \n\ .fs-selectAll.selected {\n\ float: right;\n\ cursor: pointer;\n\ margin-top: 4px;\n\ height: auto;\n\ color: green\n\ }\n\ \n\ .fs-selectAll:hover {\n\ background-color: #35d5ff\n\ }\n\ \n\ .fs-option,\n\ .fs-search,\n\ .fs-optgroup-label {\n\ padding: 6px 8px;\n\ border-bottom: 1px solid #eee;\n\ cursor: default\n\ }\n\ \n\ .fs-option {cursor: pointer}\n\ .fs-option.hl {\n\ background-color: #f5f5f5\n\ }\n\ \n\ .fs-wrap.multiple .fs-option {\n\ position: relative;\n\ padding-left: 30px\n\ }\n\ \n\ .fs-wrap.multiple .fs-checkbox {\n\ position: absolute;\n\ display: block;\n\ width: 30px;\n\ top: 0;\n\ left: 0;\n\ bottom: 0\n\ }\n\ \n\ .fs-wrap.multiple .fs-option .fs-checkbox i {\n\ position: absolute;\n\ margin: auto;\n\ left: 0;\n\ right: 0;\n\ top: 0;\n\ bottom: 0;\n\ width: 14px;\n\ height: 14px;\n\ border: 1px solid #aeaeae;\n\ border-radius: 4px;\n\ background-color: #fff\n\ }\n\ \n\ .fs-wrap.multiple .fs-option.selected .fs-checkbox i {\n\ background-color: #11a911;\n\ border-color: transparent;\n\ background-image: url();\n\ background-repeat: no-repeat;\n\ background-position: center\n\ }\n\ \n\ .fs-wrap .fs-option:hover {\n\ background: #48E3FF;\n\ border-radius: 4px;\n\ margin-left: 2px;\n\ margin-right: 2px\n\ }\n\ \n\ .fs-optgroup-label {font-weight: 700}\n\ \n\ .hidden {display: none}\n\ \n\ .fs-options::-webkit-scrollbar {width: 6px}\n\ \n\ .fs-options::-webkit-scrollbar-track {\n\ -webkit-border-radius: 2em;\n\ -moz-border-radius: 2em;\n\ border-radius: 2em;\n\ -webkit-box-shadow: inset 0 0 5px rgba(0, 0, 0, .2);\n\ background: rgba(0, 0, 0, .1)\n\ }\n\ \n\ .fs-options::-webkit-scrollbar-thumb {\n\ -webkit-box-shadow: inset 0 0 5px rgba(0, 0, 0, .2);\n\ background: rgba(0, 0, 0, .2);\n\ -webkit-border-radius: 2em;\n\ -moz-border-radius: 2em;\n\ border-radius: 2em\n\ }\n\ '; var jquery_localizationTool_css = '\ .flag {\n\ width: 16px;\n\ height: 11px;\n\ background: url(flags.png) no-repeat;\n\ }\n\ .flag.flag-ad {\n\ background-position: -16px 0;\n\ }\n\ .flag.flag-ae {\n\ background-position: -32px 0;\n\ }\n\ .flag.flag-af {\n\ background-position: -48px 0;\n\ }\n\ .flag.flag-ag {\n\ background-position: -64px 0;\n\ }\n\ .flag.flag-ai {\n\ background-position: -80px 0;\n\ }\n\ .flag.flag-al {\n\ background-position: -96px 0;\n\ }\n\ .flag.flag-am {\n\ background-position: -112px 0;\n\ }\n\ .flag.flag-an {\n\ background-position: -128px 0;\n\ }\n\ .flag.flag-ao {\n\ background-position: -144px 0;\n\ }\n\ .flag.flag-ar {\n\ background-position: -160px 0;\n\ }\n\ .flag.flag-as {\n\ background-position: -176px 0;\n\ }\n\ .flag.flag-at {\n\ background-position: -192px 0;\n\ }\n\ .flag.flag-au {\n\ background-position: -208px 0;\n\ }\n\ .flag.flag-aw {\n\ background-position: -224px 0;\n\ }\n\ .flag.flag-az {\n\ background-position: -240px 0;\n\ }\n\ .flag.flag-ba {\n\ background-position: 0 -11px;\n\ }\n\ .flag.flag-bb {\n\ background-position: -16px -11px;\n\ }\n\ .flag.flag-bd {\n\ background-position: -32px -11px;\n\ }\n\ .flag.flag-be {\n\ background-position: -48px -11px;\n\ }\n\ .flag.flag-bf {\n\ background-position: -64px -11px;\n\ }\n\ .flag.flag-bg {\n\ background-position: -80px -11px;\n\ }\n\ .flag.flag-bh {\n\ background-position: -96px -11px;\n\ }\n\ .flag.flag-bi {\n\ background-position: -112px -11px;\n\ }\n\ .flag.flag-bj {\n\ background-position: -128px -11px;\n\ }\n\ .flag.flag-bm {\n\ background-position: -144px -11px;\n\ }\n\ .flag.flag-bn {\n\ background-position: -160px -11px;\n\ }\n\ .flag.flag-bo {\n\ background-position: -176px -11px;\n\ }\n\ .flag.flag-br {\n\ background-position: -192px -11px;\n\ }\n\ .flag.flag-bs {\n\ background-position: -208px -11px;\n\ }\n\ .flag.flag-bt {\n\ background-position: -224px -11px;\n\ }\n\ .flag.flag-bv {\n\ background-position: -240px -11px;\n\ }\n\ .flag.flag-bw {\n\ background-position: 0 -22px;\n\ }\n\ .flag.flag-by {\n\ background-position: -16px -22px;\n\ }\n\ .flag.flag-bz {\n\ background-position: -32px -22px;\n\ }\n\ .flag.flag-ca {\n\ background-position: -48px -22px;\n\ }\n\ .flag.flag-catalonia {\n\ background-position: -64px -22px;\n\ }\n\ .flag.flag-cd {\n\ background-position: -80px -22px;\n\ }\n\ .flag.flag-cf {\n\ background-position: -96px -22px;\n\ }\n\ .flag.flag-cg {\n\ background-position: -112px -22px;\n\ }\n\ .flag.flag-ch {\n\ background-position: -128px -22px;\n\ }\n\ .flag.flag-ci {\n\ background-position: -144px -22px;\n\ }\n\ .flag.flag-ck {\n\ background-position: -160px -22px;\n\ }\n\ .flag.flag-cl {\n\ background-position: -176px -22px;\n\ }\n\ .flag.flag-cm {\n\ background-position: -192px -22px;\n\ }\n\ .flag.flag-cn {\n\ background-position: -208px -22px;\n\ }\n\ .flag.flag-co {\n\ background-position: -224px -22px;\n\ }\n\ .flag.flag-cr {\n\ background-position: -240px -22px;\n\ }\n\ .flag.flag-cu {\n\ background-position: 0 -33px;\n\ }\n\ .flag.flag-cv {\n\ background-position: -16px -33px;\n\ }\n\ .flag.flag-cw {\n\ background-position: -32px -33px;\n\ }\n\ .flag.flag-cy {\n\ background-position: -48px -33px;\n\ }\n\ .flag.flag-cz {\n\ background-position: -64px -33px;\n\ }\n\ .flag.flag-de {\n\ background-position: -80px -33px;\n\ }\n\ .flag.flag-dj {\n\ background-position: -96px -33px;\n\ }\n\ .flag.flag-dk {\n\ background-position: -112px -33px;\n\ }\n\ .flag.flag-dm {\n\ background-position: -128px -33px;\n\ }\n\ .flag.flag-do {\n\ background-position: -144px -33px;\n\ }\n\ .flag.flag-dz {\n\ background-position: -160px -33px;\n\ }\n\ .flag.flag-ec {\n\ background-position: -176px -33px;\n\ }\n\ .flag.flag-ee {\n\ background-position: -192px -33px;\n\ }\n\ .flag.flag-eg {\n\ background-position: -208px -33px;\n\ }\n\ .flag.flag-eh {\n\ background-position: -224px -33px;\n\ }\n\ .flag.flag-england {\n\ background-position: -240px -33px;\n\ }\n\ .flag.flag-er {\n\ background-position: 0 -44px;\n\ }\n\ .flag.flag-es {\n\ background-position: -16px -44px;\n\ }\n\ .flag.flag-esperanto {\n\ background-position: -192px -165px;\n\ }\n\ .flag.flag-et {\n\ background-position: -32px -44px;\n\ }\n\ .flag.flag-eu {\n\ background-position: -48px -44px;\n\ }\n\ .flag.flag-fi {\n\ background-position: -64px -44px;\n\ }\n\ .flag.flag-fj {\n\ background-position: -80px -44px;\n\ }\n\ .flag.flag-fk {\n\ background-position: -96px -44px;\n\ }\n\ .flag.flag-fm {\n\ background-position: -112px -44px;\n\ }\n\ .flag.flag-fo {\n\ background-position: -128px -44px;\n\ }\n\ .flag.flag-fr {\n\ background-position: -144px -44px;\n\ }\n\ .flag.flag-ga {\n\ background-position: -160px -44px;\n\ }\n\ .flag.flag-gb {\n\ background-position: -176px -44px;\n\ }\n\ .flag.flag-gd {\n\ background-position: -192px -44px;\n\ }\n\ .flag.flag-ge {\n\ background-position: -208px -44px;\n\ }\n\ .flag.flag-gf {\n\ background-position: -224px -44px;\n\ }\n\ .flag.flag-gg {\n\ background-position: -240px -44px;\n\ }\n\ .flag.flag-gh {\n\ background-position: 0 -55px;\n\ }\n\ .flag.flag-gi {\n\ background-position: -16px -55px;\n\ }\n\ .flag.flag-gl {\n\ background-position: -32px -55px;\n\ }\n\ .flag.flag-gm {\n\ background-position: -48px -55px;\n\ }\n\ .flag.flag-gn {\n\ background-position: -64px -55px;\n\ }\n\ .flag.flag-gp {\n\ background-position: -80px -55px;\n\ }\n\ .flag.flag-gq {\n\ background-position: -96px -55px;\n\ }\n\ .flag.flag-gr {\n\ background-position: -112px -55px;\n\ }\n\ .flag.flag-gs {\n\ background-position: -128px -55px;\n\ }\n\ .flag.flag-gt {\n\ background-position: -144px -55px;\n\ }\n\ .flag.flag-gu {\n\ background-position: -160px -55px;\n\ }\n\ .flag.flag-gw {\n\ background-position: -176px -55px;\n\ }\n\ .flag.flag-gy {\n\ background-position: -192px -55px;\n\ }\n\ .flag.flag-hk {\n\ background-position: -208px -55px;\n\ }\n\ .flag.flag-hm {\n\ background-position: -224px -55px;\n\ }\n\ .flag.flag-hn {\n\ background-position: -240px -55px;\n\ }\n\ .flag.flag-hr {\n\ background-position: 0 -66px;\n\ }\n\ .flag.flag-ht {\n\ background-position: -16px -66px;\n\ }\n\ .flag.flag-hu {\n\ background-position: -32px -66px;\n\ }\n\ .flag.flag-ic {\n\ background-position: -48px -66px;\n\ }\n\ .flag.flag-id {\n\ background-position: -64px -66px;\n\ }\n\ .flag.flag-ie {\n\ background-position: -80px -66px;\n\ }\n\ .flag.flag-il {\n\ background-position: -96px -66px;\n\ }\n\ .flag.flag-im {\n\ background-position: -112px -66px;\n\ }\n\ .flag.flag-in {\n\ background-position: -128px -66px;\n\ }\n\ .flag.flag-io {\n\ background-position: -144px -66px;\n\ }\n\ .flag.flag-iq {\n\ background-position: -160px -66px;\n\ }\n\ .flag.flag-ir {\n\ background-position: -176px -66px;\n\ }\n\ .flag.flag-is {\n\ background-position: -192px -66px;\n\ }\n\ .flag.flag-it {\n\ background-position: -208px -66px;\n\ }\n\ .flag.flag-je {\n\ background-position: -224px -66px;\n\ }\n\ .flag.flag-jm {\n\ background-position: -240px -66px;\n\ }\n\ .flag.flag-jo {\n\ background-position: 0 -77px;\n\ }\n\ .flag.flag-jp {\n\ background-position: -16px -77px;\n\ }\n\ .flag.flag-ke {\n\ background-position: -32px -77px;\n\ }\n\ .flag.flag-kg {\n\ background-position: -48px -77px;\n\ }\n\ .flag.flag-kh {\n\ background-position: -64px -77px;\n\ }\n\ .flag.flag-ki {\n\ background-position: -80px -77px;\n\ }\n\ .flag.flag-km {\n\ background-position: -96px -77px;\n\ }\n\ .flag.flag-kn {\n\ background-position: -112px -77px;\n\ }\n\ .flag.flag-kp {\n\ background-position: -128px -77px;\n\ }\n\ .flag.flag-kr {\n\ background-position: -144px -77px;\n\ }\n\ .flag.flag-kurdistan {\n\ background-position: -160px -77px;\n\ }\n\ .flag.flag-kw {\n\ background-position: -176px -77px;\n\ }\n\ .flag.flag-ky {\n\ background-position: -192px -77px;\n\ }\n\ .flag.flag-kz {\n\ background-position: -208px -77px;\n\ }\n\ .flag.flag-la {\n\ background-position: -224px -77px;\n\ }\n\ .flag.flag-lb {\n\ background-position: -240px -77px;\n\ }\n\ .flag.flag-lc {\n\ background-position: 0 -88px;\n\ }\n\ .flag.flag-li {\n\ background-position: -16px -88px;\n\ }\n\ .flag.flag-lk {\n\ background-position: -32px -88px;\n\ }\n\ .flag.flag-lr {\n\ background-position: -48px -88px;\n\ }\n\ .flag.flag-ls {\n\ background-position: -64px -88px;\n\ }\n\ .flag.flag-lt {\n\ background-position: -80px -88px;\n\ }\n\ .flag.flag-lu {\n\ background-position: -96px -88px;\n\ }\n\ .flag.flag-lv {\n\ background-position: -112px -88px;\n\ }\n\ .flag.flag-ly {\n\ background-position: -128px -88px;\n\ }\n\ .flag.flag-ma {\n\ background-position: -144px -88px;\n\ }\n\ .flag.flag-mc {\n\ background-position: -160px -88px;\n\ }\n\ .flag.flag-md {\n\ background-position: -176px -88px;\n\ }\n\ .flag.flag-me {\n\ background-position: -192px -88px;\n\ }\n\ .flag.flag-mg {\n\ background-position: -208px -88px;\n\ }\n\ .flag.flag-mh {\n\ background-position: -224px -88px;\n\ }\n\ .flag.flag-mk {\n\ background-position: -240px -88px;\n\ }\n\ .flag.flag-ml {\n\ background-position: 0 -99px;\n\ }\n\ .flag.flag-mm {\n\ background-position: -16px -99px;\n\ }\n\ .flag.flag-mn {\n\ background-position: -32px -99px;\n\ }\n\ .flag.flag-mo {\n\ background-position: -48px -99px;\n\ }\n\ .flag.flag-mp {\n\ background-position: -64px -99px;\n\ }\n\ .flag.flag-mq {\n\ background-position: -80px -99px;\n\ }\n\ .flag.flag-mr {\n\ background-position: -96px -99px;\n\ }\n\ .flag.flag-ms {\n\ background-position: -112px -99px;\n\ }\n\ .flag.flag-mt {\n\ background-position: -128px -99px;\n\ }\n\ .flag.flag-mu {\n\ background-position: -144px -99px;\n\ }\n\ .flag.flag-mv {\n\ background-position: -160px -99px;\n\ }\n\ .flag.flag-mw {\n\ background-position: -176px -99px;\n\ }\n\ .flag.flag-mx {\n\ background-position: -192px -99px;\n\ }\n\ .flag.flag-my {\n\ background-position: -208px -99px;\n\ }\n\ .flag.flag-mz {\n\ background-position: -224px -99px;\n\ }\n\ .flag.flag-na {\n\ background-position: -240px -99px;\n\ }\n\ .flag.flag-nc {\n\ background-position: 0 -110px;\n\ }\n\ .flag.flag-ne {\n\ background-position: -16px -110px;\n\ }\n\ .flag.flag-nf {\n\ background-position: -32px -110px;\n\ }\n\ .flag.flag-ng {\n\ background-position: -48px -110px;\n\ }\n\ .flag.flag-ni {\n\ background-position: -64px -110px;\n\ }\n\ .flag.flag-nl {\n\ background-position: -80px -110px;\n\ }\n\ .flag.flag-no {\n\ background-position: -96px -110px;\n\ }\n\ .flag.flag-np {\n\ background-position: -112px -110px;\n\ }\n\ .flag.flag-nr {\n\ background-position: -128px -110px;\n\ }\n\ .flag.flag-nu {\n\ background-position: -144px -110px;\n\ }\n\ .flag.flag-nz {\n\ background-position: -160px -110px;\n\ }\n\ .flag.flag-om {\n\ background-position: -176px -110px;\n\ }\n\ .flag.flag-pa {\n\ background-position: -192px -110px;\n\ }\n\ .flag.flag-pe {\n\ background-position: -208px -110px;\n\ }\n\ .flag.flag-pf {\n\ background-position: -224px -110px;\n\ }\n\ .flag.flag-pg {\n\ background-position: -240px -110px;\n\ }\n\ .flag.flag-ph {\n\ background-position: 0 -121px;\n\ }\n\ .flag.flag-pk {\n\ background-position: -16px -121px;\n\ }\n\ .flag.flag-pl {\n\ background-position: -32px -121px;\n\ }\n\ .flag.flag-pm {\n\ background-position: -48px -121px;\n\ }\n\ .flag.flag-pn {\n\ background-position: -64px -121px;\n\ }\n\ .flag.flag-pr {\n\ background-position: -80px -121px;\n\ }\n\ .flag.flag-ps {\n\ background-position: -96px -121px;\n\ }\n\ .flag.flag-pt {\n\ background-position: -112px -121px;\n\ }\n\ .flag.flag-pw {\n\ background-position: -128px -121px;\n\ }\n\ .flag.flag-py {\n\ background-position: -144px -121px;\n\ }\n\ .flag.flag-qa {\n\ background-position: -160px -121px;\n\ }\n\ .flag.flag-re {\n\ background-position: -176px -121px;\n\ }\n\ .flag.flag-ro {\n\ background-position: -192px -121px;\n\ }\n\ .flag.flag-rs {\n\ background-position: -208px -121px;\n\ }\n\ .flag.flag-ru {\n\ background-position: -224px -121px;\n\ }\n\ .flag.flag-rw {\n\ background-position: -240px -121px;\n\ }\n\ .flag.flag-sa {\n\ background-position: 0 -132px;\n\ }\n\ .flag.flag-sb {\n\ background-position: -16px -132px;\n\ }\n\ .flag.flag-sc {\n\ background-position: -32px -132px;\n\ }\n\ .flag.flag-scotland {\n\ background-position: -48px -132px;\n\ }\n\ .flag.flag-sd {\n\ background-position: -64px -132px;\n\ }\n\ .flag.flag-se {\n\ background-position: -80px -132px;\n\ }\n\ .flag.flag-sg {\n\ background-position: -96px -132px;\n\ }\n\ .flag.flag-sh {\n\ background-position: -112px -132px;\n\ }\n\ .flag.flag-si {\n\ background-position: -128px -132px;\n\ }\n\ .flag.flag-sk {\n\ background-position: -144px -132px;\n\ }\n\ .flag.flag-sl {\n\ background-position: -160px -132px;\n\ }\n\ .flag.flag-sm {\n\ background-position: -176px -132px;\n\ }\n\ .flag.flag-sn {\n\ background-position: -192px -132px;\n\ }\n\ .flag.flag-so {\n\ background-position: -208px -132px;\n\ }\n\ .flag.flag-somaliland {\n\ background-position: -224px -132px;\n\ }\n\ .flag.flag-sr {\n\ background-position: -240px -132px;\n\ }\n\ .flag.flag-ss {\n\ background-position: 0 -143px;\n\ }\n\ .flag.flag-st {\n\ background-position: -16px -143px;\n\ }\n\ .flag.flag-sv {\n\ background-position: -32px -143px;\n\ }\n\ .flag.flag-sx {\n\ background-position: -48px -143px;\n\ }\n\ .flag.flag-sy {\n\ background-position: -64px -143px;\n\ }\n\ .flag.flag-sz {\n\ background-position: -80px -143px;\n\ }\n\ .flag.flag-tc {\n\ background-position: -96px -143px;\n\ }\n\ .flag.flag-td {\n\ background-position: -112px -143px;\n\ }\n\ .flag.flag-tf {\n\ background-position: -128px -143px;\n\ }\n\ .flag.flag-tg {\n\ background-position: -144px -143px;\n\ }\n\ .flag.flag-th {\n\ background-position: -160px -143px;\n\ }\n\ .flag.flag-tj {\n\ background-position: -176px -143px;\n\ }\n\ .flag.flag-tk {\n\ background-position: -192px -143px;\n\ }\n\ .flag.flag-tl {\n\ background-position: -208px -143px;\n\ }\n\ .flag.flag-tm {\n\ background-position: -224px -143px;\n\ }\n\ .flag.flag-tn {\n\ background-position: -240px -143px;\n\ }\n\ .flag.flag-to {\n\ background-position: 0 -154px;\n\ }\n\ .flag.flag-tr {\n\ background-position: -16px -154px;\n\ }\n\ .flag.flag-tt {\n\ background-position: -32px -154px;\n\ }\n\ .flag.flag-tv {\n\ background-position: -48px -154px;\n\ }\n\ .flag.flag-tw {\n\ background-position: -64px -154px;\n\ }\n\ .flag.flag-tz {\n\ background-position: -80px -154px;\n\ }\n\ .flag.flag-ua {\n\ background-position: -96px -154px;\n\ }\n\ .flag.flag-ug {\n\ background-position: -112px -154px;\n\ }\n\ .flag.flag-um {\n\ background-position: -128px -154px;\n\ }\n\ .flag.flag-us {\n\ background-position: -144px -154px;\n\ }\n\ .flag.flag-uy {\n\ background-position: -160px -154px;\n\ }\n\ .flag.flag-uz {\n\ background-position: -176px -154px;\n\ }\n\ .flag.flag-va {\n\ background-position: -192px -154px;\n\ }\n\ .flag.flag-vc {\n\ background-position: -208px -154px;\n\ }\n\ .flag.flag-ve {\n\ background-position: -224px -154px;\n\ }\n\ .flag.flag-vg {\n\ background-position: -240px -154px;\n\ }\n\ .flag.flag-vi {\n\ background-position: 0 -165px;\n\ }\n\ .flag.flag-vn {\n\ background-position: -16px -165px;\n\ }\n\ .flag.flag-vu {\n\ background-position: -32px -165px;\n\ }\n\ .flag.flag-wales {\n\ background-position: -48px -165px;\n\ }\n\ .flag.flag-wf {\n\ background-position: -64px -165px;\n\ }\n\ .flag.flag-ws {\n\ background-position: -80px -165px;\n\ }\n\ .flag.flag-ye {\n\ background-position: -96px -165px;\n\ }\n\ .flag.flag-yt {\n\ background-position: -112px -165px;\n\ }\n\ .flag.flag-za {\n\ background-position: -128px -165px;\n\ }\n\ .flag.flag-zanzibar {\n\ background-position: -144px -165px;\n\ }\n\ .flag.flag-zm {\n\ background-position: -160px -165px;\n\ }\n\ .flag.flag-zw {\n\ background-position: -176px -165px;\n\ }\n\ .localizationTool:hover {\n\ cursor: pointer;\n\ cursor: hand;\n\ }\n\ .localizationTool.ltool-is-visible ul {\n\ display: block;\n\ float: left;\n\ position: absolute;\n\ width: 100%;\n\ list-style-type: none;\n\ }\n\ .localizationTool.ltool-is-visible .ltool-dropdown-label-arrow {\n\ /* the arrow */\n\ \n\ content: "";\n\ display: block;\n\ width: 0;\n\ height: 0;\n\ border-top: 10px solid transparent;\n\ border-left: 10px solid transparent;\n\ border-bottom: 10px solid #deedf7;\n\ border-right: 10px solid transparent;\n\ position: absolute;\n\ right: 8px;\n\ top: 7px;\n\ }\n\ .localizationTool {\n\ color: #333333;\n\ /* background: #8dc1e2; */\n\ background: #009688;\n\ position: relative;\n\ }\n\ .localizationTool .ltool-dropdown-label {\n\ display: block;\n\ padding: 12px 0 12px 12px;\n\ color: #FFF;\n\ border: 0;\n\ position: relative;\n\ }\n\ .localizationTool .ltool-dropdown-label img,\n\ .localizationTool .ltool-dropdown-label .ltool-language-flag {\n\ margin-left: 0;\n\ }\n\ .localizationTool .ltool-dropdown-label .ltool-language-name {\n\ color: #deedf7;\n\ }\n\ .localizationTool .ltool-dropdown-label-arrow {\n\ /* the arrow */\n\ \n\ content: "";\n\ display: block;\n\ width: 0;\n\ height: 0;\n\ border-top: 10px solid #deedf7;\n\ border-left: 10px solid transparent;\n\ border-bottom: 10px solid transparent;\n\ border-right: 10px solid transparent;\n\ position: absolute;\n\ right: 8px;\n\ top: 17px;\n\ }\n\ .localizationTool img,\n\ .localizationTool div {\n\ display: inline;\n\ }\n\ .localizationTool li {\n\ display: block;\n\ /* background: #deedf7; */\n\ background: #009688;\n\ padding: 5px;\n\ }\n\ .localizationTool li.ltool-is-selected {\n\ /* background: #f5f1d6; */\n\ background: #148B7E;\n\ }\n\ .localizationTool li:hover {\n\ /* background: #f5f1d6; */\n\ background: #148B7E;\n\ outline: 0;\n\ -webkit-appearance: none;\n\ transition: all .3s;\n\ -webkit-transition: all .3s;\n\ box-sizing: border-box;\n\ }\n\ .localizationTool img {\n\ width: 16px;\n\ height: 11px;\n\ }\n\ .localizationTool .ltool-language-name {\n\ /* color: #8dc1e2; */\n\ color: #ebebeb;\n\ }\n\ .localizationTool .ltool-language-flag {\n\ display: block;\n\ float: left;\n\ margin-top: 3px;\n\ }\n\ .localizationTool .ltool-language-flag,\n\ .localizationTool .ltool-language-countryname {\n\ margin-left: 8px;\n\ }\n\ .localizationTool ul {\n\ margin: 0;\n\ padding: 0;\n\ display: none;\n\ }\n\ '; var loadUI_css = '\ position: absolute;\n\ left: 0; right: 0; top: 0;\n\ z-index: 10;\n\ background: url(https://steamcommunity-a.akamaihd.net/public/images/friends/colored_body_top2.png?v=2) center top no-repeat #1b2838;\n\ '; var load_cssCode = '\ @charset "utf-8";\n\ @import url("https://fonts.googleapis.com/css?family=Fredoka+One|Open+Sans:300");\n\ *,\n\ *::before,\n\ *::after {\n\ box-sizing: border-box;\n\ }\n\ \n\ body {\n\ font-family: "Fredoka One", cursive;\n\ font-size: 16px;\n\ margin: 0px;\n\ }\n\ \n\ #loadingUI {\n\ display: -webkit-box;\n\ display: -ms-flexbox;\n\ display: flex;\n\ -webkit-box-pack: center;\n\ -ms-flex-pack: center;\n\ justify-content: center;\n\ -webkit-box-align: center;\n\ -ms-flex-align: center;\n\ align-items: center;\n\ min-height: 100vh;\n\ /* background: rgba(249, 249, 249, 0.9); */\n\ overflow: hidden;\n\ }\n\ \n\ .text-wrapper {\n\ padding: 0 1rem;\n\ max-width: 50rem;\n\ width: 100%;\n\ text-align: center;\n\ }\n\ \n\ .text {\n\ font-size: 8em;\n\ text-transform: uppercase;\n\ letter-spacing: -14px;\n\ }\n\ \n\ .text .letter {\n\ position: relative;\n\ display: inline-block;\n\ -webkit-transition: all .4s;\n\ transition: all .4s;\n\ }\n\ \n\ .text .letter .character {\n\ opacity: 0.65;\n\ -webkit-transition: color .4s;\n\ transition: color .4s;\n\ cursor: pointer;\n\ }\n\ \n\ .text .letter span {\n\ position: absolute;\n\ bottom: .8rem;\n\ left: .4rem;\n\ display: block;\n\ width: 100%;\n\ height: 15px;\n\ }\n\ \n\ .text .letter span::before {\n\ content: "";\n\ position: absolute;\n\ top: 50%;\n\ left: 50%;\n\ width: 0;\n\ height: 0;\n\ -webkit-transform: translate(-50%, -50%);\n\ transform: translate(-50%, -50%);\n\ border-radius: 50%;\n\ background: rgba(0, 0, 0, 0.25);\n\ }\n\ \n\ .text .letter:hover .character {\n\ color: #fff !important;\n\ }\n\ \n\ .text.part1 .letter:nth-child(1).poofed {\n\ -webkit-transform-origin: 50% 50%;\n\ transform-origin: 50% 50%;\n\ -webkit-animation: poofing1 1.4s ease-i\n-out infinite alternate;\n\ animation: poofing1 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes poofing1 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(459deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(459deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(459deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(459deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes poofing1 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(459deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(459deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(459deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(459deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part1 .letter:nth-child(1) .character {\n\ color: #f44336;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 0.33333s;\n\ animation-delay: 0.33333s;\n\ }\n\ \n\ .text.part1 .letter:nth-child(1) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 0.33333s;\n\ animation-delay: 0.33333s;\n\ }\n\ \n\ .text.part1 .letter:nth-child(2).poofed {\n\ -webkit-transform-origin: 50% 50%;\n\ transform-origin: 50% 50%;\n\ -webkit-animation: poofing2 1.4s ease-in-out infinite alternate;\n\ animation: poofing2 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes poofing2 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(540deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(540deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(540deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(540deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes poofing2 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(540deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(540deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(540deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(540deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part1 .letter:nth-child(2) .character {\n\ color: #9C27B0;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 0.66667s;\n\ animation-delay: 0.66667s;\n\ }\n\ \n\ .text.part1 .letter:nth-child(2) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 0.66667s;\n\ animation-delay: 0.66667s;\n\ }\n\ \n\ .text.part1 .letter:nth-child(3).poofed {\n\ -webkit-transform-origin: 50% 50%;\n\ transform-origin: 50% 50%;\n\ -webkit-animation: poofing3 1.4s ease-in-out infinite alternate;\n\ animation: poofing3 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes poofing3 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(264deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(264deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(264deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(264deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes poofing3 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(264deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(264deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(264deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(264deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part1 .letter:nth-child(3) .character {\n\ color: #f99b0c;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 1s;\n\ animation-delay: 1s;\n\ }\n\ \n\ .text.part1 .letter:nth-child(3) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 1s;\n\ animation-delay: 1s;\n\ }\n\ \n\ .text.part1 .letter:nth-child(4).poofed {\n\ -webkit-transform-origin: 50% 50%;\n\ transform-origin: 50% 50%;\n\ -webkit-animation: poofing4 1.4s ease-in-out infinite alternate;\n\ animation: poofing4 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes poofing4 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(42deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(42deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(42deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(42deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes poofing4 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(42deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(42deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(42deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(42deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part1 .letter:nth-child(4) .character {\n\ color: #cee007;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 1.33333s;\n\ animation-delay: 1.33333s;\n\ }\n\ \n\ .text.part1 .letter:nth-child(4) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 1.33333s;\n\ animation-delay: 1.33333s;\n\ }\n\ \n\ .text.part1 .letter:nth-child(5).poofed {\n\ -webkit-transform-origin: 50% 50%;\n\ transform-origin: 50% 50%;\n\ -webkit-animation: poofing5 1.4s ease-in-out infinite alternate;\n\ animation: poofing5 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes poofing5 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(384deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(384deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(384deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(384deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes poofing5 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(384deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(384deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(384deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(384deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part1 .letter:nth-child(5) .character {\n\ color: #00c6b2;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 1.66667s\n\ animation-delay: 1.66667s;\n\ }\n\ \n\ .text.part1 .letter:nth-child(5) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 1.66667s;\n\ animation-delay: 1.66667s;\n\ }\n\ \n\ .text.part1 .letter:nth-child(6).poofed {\n\ -webkit-transform-origin: 50% 50%;\n\ transform-origin: 50% 50%;\n\ -webkit-animation: poofing6 1.4s ease-in-out infinite alternate;\n\ animation: poofing6 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes poofing6 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(156deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(156deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(156deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(156deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes poofing6 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(156deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(156deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(156deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(156deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part1 .letter:nth-child(6) .character {\n\ color: #f44336;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 2s;\n\ animation-delay: 2s;\n\ }\n\ \n\ .text.part1 .letter:nth-child(6) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 2s;\n\ animation-delay: 2s;\n\ }\n\ \n\ .text.part1 .letter:nth-child(7).poofed {\n\ -webkit-transform-origin: 50% 50%;\n\ transform-origin: 50% 50%;\n\ -webkit-animation: poofing7 1.4s ease-in-out infinite alternate;\n\ animation: poofing7 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes poofing7 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(156deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(156deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(156deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(156deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes poofing7 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(156deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(156deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(156deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(156deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part1 .letter:nth-child(7) .character {\n\ color: #4CAF50;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 2s;\n\ animation-delay: 2.5s;\n\ }\n\ \n\ .text.part1 .letter:nth-child(7) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 2s;\n\ animation-delay: 3s;\n\ }\n\ \n\ .text.part2 span:nth-child(1).poofed {\n\ -webkit-animation: sec_poofing1 1.4s ease-in-out infinite alternate;\n\ animation: sec_poofing1 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes sec_poofing1 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(268deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(268deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(268deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(268deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes sec_poofing1 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(268deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(268deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(268deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(268deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part2 span:nth-child(1) .character {\n\ color: #ff5a5f;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 2.33333s;\n\ animation-delay: 2.33333s;\n\ }\n\ \n\ .text.part2 span:nth-child(1) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 2.33333s;\n\ animation-delay: 2.33333s;\n\ }\n\ \n\ .text.part2 span:nth-child(2).poofed {\n\ -webkit-animation: sec_poofing2 1.4s ease-in-out infinite alternate;\n\ animation: sec_poofing2 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes sec_poofing2 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(135deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(135deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(135deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(135deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes sec_poofing2 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(135deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(135deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(135deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(135deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part2 span:nth-child(2) .character {\n\ color: #f99b0c;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 2.66667s;\n\ animation-delay: 2.66667s;\n\ }\n\ \n\ .text.part2 span:nth-child(2) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 2.66667s;\n\ animation-delay: 2.66667s;\n\ }\n\ \n\ .text.part2 span:nth-child(3).poofed {\n\ -webkit-animation: sec_poofing3 1.4s ease-in-out infinite alternate;\n\ animation: sec_poofing3 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes sec_poofing3 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(442deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(442deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(442deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(442deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes sec_poofing3 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(442deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(442deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(442deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(442deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part2 span:nth-child(3) .character {\n\ color: #cee007;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 3s;\n\ animation-delay: 3s;\n\ }\n\ \n\ .text.part2 span:nth-child(3) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 3s;\n\ animation-delay: 3s;\n\ }\n\ \n\ .text.part2 span:nth-child(4).poofed {\n\ -webkit-animation: sec_poofing4 1.4s ease-in-out infinite alternate;\n\ animation: sec_poofing4 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes sec_poofing4 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(525deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(525deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(525deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(525deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes sec_poofing4 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(525deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(525deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(525deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(525deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part2 span:nth-child(4) .character {\n\ color: #00c6b2;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 3.33333s;\n\ animation-delay: 3.33333s;\n\ }\n\ \n\ .text.part2 span:nth-child(4) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 3.33333s;\n\ animation-delay: 3.33333s;\n\ }\n\ \n\ .text.part2 span:nth-child(5).poofed {\n\ -webkit-animation: sec_poofing5 1.4s ease-in-out infinite alternate;\n\ animation: sec_poofing5 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes sec_poofing5 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(419deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(419deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(419deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(419deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes sec_poofing5 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(419deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(419deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(419deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(419deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part2 span:nth-child(5) .character {\n\ color: #4e2a84;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 3.66667s;\n\ animation-delay: 3.66667s;\n\ }\n\ \n\ .text.part2 span:nth-child(5) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 3.66667s;\n\ animation-delay: 3.66667s;\n\ }\n\ \n\ .text.part2 span:nth-child(6).poofed {\n\ -webkit-animation: sec_poofing6 1.4s ease-in-out infinite alternate;\n\ animation: sec_poofing6 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes sec_poofing6 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(246deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(246deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(246deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(246deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes sec_poofing6 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(246deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(246deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(246deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(246deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part2 span:nth-child(6) .character {\n\ color: #9C27B0;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 4s;\n\ animation-delay: 4s;\n\ }\n\ \n\ .text.part2 span:nth-child(6) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 4s;\n\ animation-delay: 4s;\n\ }\n\ \n\ .text.part2 span:nth-child(7).poofed {\n\ -webkit-animation: sec_poofing7 1.4s ease-in-out infinite alternate;\n\ animation: sec_poofing7 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes sec_poofing7 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(206deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(206deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(206deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(206deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes sec_poofing7 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(206deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(206deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(206deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(206deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part2 span:nth-child(7) .character {\n\ color: #f99b0c;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 4.33333s;\n\ animation-delay: 4.33333s;\n\ }\n\ \n\ .text.part2 span:nth-child(7) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 4.33333s;\n\ animation-delay: 4.33333s;\n\ }\n\ \n\ .text.part2 span:nth-child(8).poofed {\n\ -webkit-animation: sec_poofing8 1.4s ease-in-out infinite alternate;\n\ animation: sec_poofing8 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes sec_poofing8 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(60deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(60deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(60deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(60deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes sec_poofing8 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(60deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(60deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(60deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(60deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part2 span:nth-child(8) .character {\n\ color: #cee007;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 4.66667s;\n\ animation-delay: 4.66667s;\n\ }\n\ \n\ .text.part2 span:nth-child(8) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 4.66667s;\n\ animation-delay: 4.66667s;\n\ }\n\ \n\ .text.part2 span:nth-child(9).poofed {\n\ -webkit-animation: sec_poofing9 1.4s ease-in-out infinite alternate;\n\ animation: sec_poofing9 1.4s ease-in-out infinite alternate;\n\ }\n\ \n\ @-webkit-keyframes sec_poofing9 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(496deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(496deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(496deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(496deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ @keyframes sec_poofing9 {\n\ 0% {\n\ -webkit-transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(0) translateY(0px) scale(1);\n\ }\n\ 50% {\n\ -webkit-transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(0deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 56% {\n\ -webkit-transform: rotateZ(496deg) rotateY(360deg) translateY(0px) scale(1);\n\ transform: rotateZ(496deg) rotateY(360deg) translateY(0px) scale(1);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(496deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ transform: rotateZ(496deg) rotateY(360deg) translateY(-700px) scale(0.01);\n\ }\n\ }\n\ \n\ .text.part2 span:nth-child(9) .character {\n\ color: #00c6b2;\n\ -webkit-animation: wave 1.2s linear infinite;\n\ animation: wave 1.2s linear infinite;\n\ -webkit-animation-delay: 5s;\n\ animation-delay: 5s;\n\ }\n\ \n\ .text.part2 span:nth-child(9) span::before {\n\ -webkit-animation: shadow 1.2s linear infinite;\n\ animation: shadow 1.2s linear infinite;\n\ -webkit-animation-delay: 5s;\n\ animation-delay: 5s;\n\ }\n\ \n\ @-webkit-keyframes wave {\n\ 0% {\n\ -webkit-transform: translateY(0);\n\ transform: translateY(0);\n\ }\n\ 50% {\n\ -webkit-transform: translateY(-10px);\n\ transform: translateY(-10px);\n\ }\n\ 100% {\n\ -webkit-transform: translateY(0);\n\ transform: translateY(0);\n\ }\n\ }\n\ \n\ @keyframes wave {\n\ 0% {\n\ -webkit-transform: translateY(0);\n\ transform: translateY(0);\n\ }\n\ 50% {\n\ -webkit-transform: translateY(-10px);\n\ transform: translateY(-10px);\n\ }\n\ 100% {\n\ -webkit-transform: translateY(0);\n\ transform: translateY(0);\n\ }\n\ }\n\ \n\ @-webkit-keyframes shadow {\n\ 0% {\n\ width: 0;\n\ height: 0;\n\ }\n\ 50% {\n\ width: 100%;\n\ height: 100%;\n\ }\n\ 100% {\n\ width: 0;\n\ height: 0;\n\ }\n\ }\n\ \n\ @keyframes shadow {\n\ 0% {\n\ width: 0;\n\ height: 0;\n\ }\n\ 50% {\n\ width: 100%;\n\ height: 100%;\n\ }\n\ 100% {\n\ width: 0;\n\ height: 0;\n\ }\n\ }\n\ \n\ .how-to {\n\ margin: 2rem 0 2rem 1rem;\n\ font-family: "Opens Sans", sans-serif;\n\ font-weight: 300;\n\ font-size: .85em;\n\ letter-spacing: 4px;\n\ /*color: rgba(0, 0, 0, 0.8);*/\n\ color: rgba(255, 255, 255, 0.8);\n\ }\n\ \n\ @-webkit-keyframes rotate {\n\ 0% {\n\ -webkit-transform: rotateZ(0) scale(0.7);\n\ transform: rotateZ(0) scale(0.7);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(360deg) scale(0.7);\n\ transform: rotateZ(360deg) scale(0.7);\n\ }\n\ }\n\ \n\ @keyframes rotate {\n\ 0% {\n\ -webkit-transform: rotateZ(0) scale(0.7);\n\ transform: rotateZ(0) scale(0.7);\n\ }\n\ 100% {\n\ -webkit-transform: rotateZ(360deg) scale(0.7);\n\ transform: rotateZ(360deg) scale(0.7);\n\ }\n\ }\n\ \n\ @media only screen and (max-width: 767px) {\n\ .text {\n\ font-size: 6em;\n\ }\n\ .text .letter span {\n\ bottom: .5rem;\n\ }\n\ }\n\ \n\ @media only screen and (max-width: 480px) {\n\ .text {\n\ font-size: 4em;\n\ }\n\ .text .letter span {\n\ bottom: 0;\n\ }\n\ }\n\ '; var ExpandUI_QuickNavigationBar_html = '\ /*拓展UI-快捷导航栏的html代码*/\n\ <div style="position: fixed;top: 30%;right: 0;">\n\ <div class="localTool-1-1 layui-input-block" style="margin-left:0; text-align: center;min-height:0;padding: 2px 0px;background: #282B33;">快捷导航栏</div>\n\ \n\ <ul class="layui-nav layui-nav-tree layui-inline" lay-filter="demo" style="margin-right: 10px;">\n\ <li class="layui-nav-item layui-nav-itemed">\n\ <a href="javascript:;">好友分组</a>\n\ <dl class="layui-nav-child">\n\ <dd><a href="javascript:;">选项一</a></dd>\n\ <dd><a href="javascript:;">选项二</a></dd>\n\ <dd><a href="javascript:;">选项三</a></dd>\n\ <dd><a href="">跳转项</a></dd>\n\ </dl>\n\ </li>\n\ \n\ <li class="layui-nav-item">\n\ <a href="javascript:;">功能模块</a>\n\ <dl class="layui-nav-child">\n\ <dd><a href="javascript:;">选项一</a></dd>\n\ <dd><a href="javascript:;">选项二</a></dd>\n\ <dd><a href="javascript:;">选项三</a></dd>\n\ <dd><a href="">跳转项</a></dd>\n\ </dl>\n\ </li>\n\ \n\ <li class="layui-nav-item">\n\ <a href="javascript:;">其他</a>\n\ <dl class="layui-nav-child">\n\ <dd><a href="javascript:;">返回顶部</a></dd>\n\ <dd><a href="javascript:;">返回底部</a></dd>\n\ <dd><a href="javascript:;">选项三</a></dd>\n\ <dd><a href="">跳转项</a></dd>\n\ </dl>\n\ </li>\n\ \n\ <li class="layui-nav-item">\n\ <a href="javascript:;">解决方案</a>\n\ <dl class="layui-nav-child">\n\ <dd><a href="">移动模块</a></dd>\n\ <dd><a href="">后台模版</a></dd>\n\ <dd><a href="">电商平台</a></dd>\n\ </dl>\n\ </li>\n\ \n\ <li class="layui-nav-item"><a href="">云市场</a></li>\n\ <li class="layui-nav-item"><a href="">社区</a></li>\n\ </ul>\n\ </div>\n\ '; var groupUI_html = '\ <div class="layui-tab layui-tab-brief" lay-filter="demo">\n\ <ul class="layui-tab-title" style="color: #ebebeb;">\n\ <li class="localTool-2-1 layui-this">留言</li>\n\ <li>留言设置</li>\n\ <li>数据分析</li>\n\ <li>点赞助手</li>\n\ <li>拓展功能(测试)</li>\n\ <li>设置</li>\n\ </ul>\n\ <div class="layui-tab-content">\n\ <div class="layui-tab-item layui-show" style="color: #ebebeb;">\n\ <!----------------------------------------------------------------------------------------------------------------->\n\ <div class="commentthread_entry">\n\ <div class="commentthread_entry_quotebox">\n\ <!--<textarea class="commentthread_textarea" id="comment_textarea" onfocus="this.focus();this.select();inBoxShrinkage(\'comment_textarea\',false);" onClick="" onblur="inBoxonblurID=0;inBoxShrinkage(\'comment_textarea\',true);" placeholder="添加留言" style="overflow: hidden; height: 28px;"></textarea>-->\n\ <textarea class="commentthread_textarea" id="comment_textarea" onfocus="inBoxonblurID=0;inBoxShrinkage(\'comment_textarea\',false);" onClick="" onblur="inBoxonblurID=0;inBoxShrinkage(\'comment_textarea\',true);" placeholder="添加留言" style="overflow: hidden; height: 28px;"></textarea>\n\ </div>\n\ \n\ <form class="layui-form" action="" lay-filter="example">\n\ <div id="strInBytes" style="color: #32CD32;display: inline-block;font-family: Consolas;font-size: 16px;">\n\ <span>当前字符字节数: </span>\n\ <span id="strInBytes_Text">0</span>\n\ <span>/999</span>\n\ </div>\n\ <div class="layui-inline">\n\ <label class="layui-form-label" style="width: auto;">文本格式(直接添加或选择文字添加)</label>\n\ <div class="layui-input-inline">\n\ <select name="modules" lay-verify="required" lay-search="" id="steamTextStyle">\n\ <option value="">直接选择或搜索选择</option>\n\ <option value="1">[h1]标题文字[/h1]</option>\n\ <option value="2">[b]粗体文本[/b]</option>\n\ <option value="3">[u]下划线文本[/u]</option>\n\ <option value="4">[i]斜体文本[/i]</option>\n\ <option value="5">[strike]删除文本[/strike]</option>\n\ <option value="6">[spoiler]隐藏文本[/spoiler]</option>\n\ <option value="7">[noparse]不解析[b]标签[/b][/noparse]</option>\n\ <option value="8">[url=store.steampowered.com]网站链接[/url]</option>\n\ </select>\n\ </div>\n\ <button type="button" class="layui-btn layui-btn-normal" id="LAY-component-form-getval">添加</button>\n\ </div>\n\ </form>\n\ \n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>翻译模块(需要提前设置国籍):</legend>\n\ </fieldset>\n\ <div id="translationOptions" style="color:#fff;">\n\ <span><span>当前语言:</span> \n\ <select id="origLanguageSelectBox" style="padding: 4px 12px 4px 8px;font-size:12px;outline:0;border: 1px solid #34DEFF;background-color:transparent;color: #66ccff;">\n\ <option name="auto" value="auto" style="color:#fff;background-color: #3E9AC6;">自动检测</option>\n\ <option name="zhc" value="zh-CN" style="color:#fff;background-color: #3E9AC6;">中文简体</option>\n\ <option name="en" value="en" style="color:#fff;background-color: #3E9AC6;">英语</option>\n\ <option name="jp" value="ja" style="color:#fff;background-color: #3E9AC6;">日语</option>\n\ </select>\n\ </span>\n\ \n\ <span style="margin-left: 5px;"><span>目标语言: </span>\n\ <select id="selectBoxID" class="selectBox" multiple="multiple">\n\ <option value="en">英语</option>\n\ <option value="ja">日语</option>\n\ <option value="zh-CN">中文简体</option>\n\ <option value="zh-sg">马新简体[zh-sg]</option>\n\ <option value="zh-hant">繁體中文[zh-hant]</option>\n\ <option value="zh-hk">繁體中文(香港)[zh-hk]</option>\n\ <option value="zh-mo">繁體中文(澳门)[zh-mo]</option>\n\ <option value="zh-tw">繁體中文(台湾)[zh-tw]</option>\n\ </select>\n\ </span>\n\ \n\ <span style="margin-left: 5px;vertical-align: middle;">\n\ <button id="translationText">翻译</button>\n\ </span>\n\ </div>\n\ \n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>添加称呼模块(需要提前设置备注):</legend>\n\ </fieldset>\n\ <div class="commentthread_entry_submitlink" style="">\n\ <span class="isCustom" style="display: block;text-align: left;">\n\ <!-- 默认为{name},可以自行修改,好友没有备注则使用steam名称 -->\n\ <span style="font-size:14px;line-height: 20px;color: #67c1f5 !important;">自定义称呼模式</span>\n\ <input class="nameAddType" id="select_isCustom_checkbox" name="nameAddType" type="radio" style="vertical-align: middle;margin:2px;">\n\ <span style="margin-left: 5px;vertical-align: middle;">\n\ <button id="addCustomName">在留言框添加自定义称呼标识符</button>\n\ </span>\n\ </span>\n\ \n\ <span class="isName" style="display: block;text-align: left;">\n\ <span style="font-size:14px;line-height: 20px;color: #67c1f5 !important;">是否为组添加称呼(如果组没有备注则使用steam名称)</span>\n\ <input class="nameAddType" id="select_islName_checkbox" name="nameAddType" type="radio" style="vertical-align: middle;margin:2px;">\n\ </span>\n\ \n\ <span class="isSpecialName" style="display: block;text-align: left;">\n\ <span style="font-size:14px;line-height: 20px;color: #67c1f5 !important;">是否为组添加称呼(如果组设置有备注则使用,否则不添加称呼)</span>\n\ <input class="nameAddType" id="select_isSpecialName_checkbox" name="nameAddType" type="radio" style="vertical-align: middle;margin:2px;">\n\ </span>\n\ \n\ <fieldset class="layui-elem-field layui-field-title" style="padding: 10px 0px;">\n\ <span style="display: block;text-align: right;">\n\ <a class="btn_grey_black btn_small_thin" href="javascript:CCommentThread.FormattingHelpPopup( \'Profile\' );">\n\ <span class="btn_grey_black btn_small_thin_text">格式化帮助</span>\n\ </a>\n\ \n\ <span class="emoticon_container">\n\ <span class="emoticon_button small" id="emoticonbtn"></span>\n\ </span>\n\ \n\ <span class="btn_green_white_innerfade btn_small" id="comment_submit">\n\ <span id="comment_submit_text">发送评论给选择的组</span>\n\ </span>\n\ \n\ <span class="btn_green_white_innerfade btn_small" id="comment_submit_special">\n\ <span id="comment_submit_special_text">根据国籍发送评论给选择的组</span>\n\ </span>\n\ </span>\n\ </div>\n\ </div>\n\ <div id="log">\n\ <span id="log_head"></span>\n\ <span id="log_body" style="display:inline-block;width:100%;overflow: hidden;white-space: nowrap;text-overflow: ellipsis; /*超出部分用...代替*/"></span>\n\ </div>\n\ <!----------------------------------------------------------------------------------------------------------------->\n\ \n\ </div>\n\ \n\ <div class="layui-tab-item" style="background-color: rgba(0,0,0,0.2); color: #ebebeb;">\n\ <div style="text-align: left;margin: 5px 0px;">\n\ <span style="margin-left: 5px;vertical-align: middle;">\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置国籍:</legend>\n\ </fieldset>\n\ <div style="color: #67c1f5;">请选择要设置的国籍:</div>\n\ <select id="nationalitySelectBox" style="padding: 4px 12px 4px 8px;font-size:12px;outline:0;border: 1px solid #34DEFF;background-color:transparent;color: #66ccff;">\n\ <option name="CN" value="CN" style="color:#fff;background-color: #3E9AC6;">简体中文</option>\n\ <option name="EN" value="EN" style="color:#fff;background-color: #3E9AC6;">英语</option>\n\ <option name="JP" value="JP" style="color:#fff;background-color: #3E9AC6;">日语</option>\n\ <option name="CN-SG" value="CN-SG" style="color:#fff;background-color: #3E9AC6;">马新简体(马来西亚,新加坡)[zh-sg]</option>\n\ <option name="CN-HANT" value="CN-HANT" style="color:#fff;background-color: #3E9AC6;">繁體中文[zh-hant]</option>\n\ <option name="CN-HK" value="CN-HK" style="color:#fff;background-color: #3E9AC6;">繁體中文(香港)[zh-hk]</option>\n\ <option name="CN-MO" value="CN-MO" style="color:#fff;background-color: #3E9AC6;">繁體中文(澳门)[zh-mo]</option>\n\ <option name="CN-TW" value="CN-TW" style="color:#fff;background-color: #3E9AC6;">繁體中文(台湾)[zh-tw]</option>\n\ </select>\n\ <button id="setNationality">为选择的好友设置国籍标识</button>\n\ </span>\n\ <span style="margin-left: 5px;vertical-align: top;">\n\ <button id="unsetNationality">为选择的好友取消国籍标识</button>\n\ </span>\n\ <br />\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置不留言:</legend>\n\ </fieldset>\n\ <div style="margin-left: 5px;vertical-align: top;margin-top:5px;">\n\ <span>\n\ <button id="setNoLeave">为选择的好友设置不留言</button>\n\ </span>\n\ <span>\n\ <button id="unsetNoLeave">为选择的好友取消设置不留言</button>\n\ </span>\n\ </div>\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置留言时间间隔:</legend>\n\ </fieldset>\n\ <div id="">只选择日期则过n天后再留言,只选择时间则过x时后再留言(严格模式),日期和时间都选择了则过n天x时后再留言(严格模式)</div>\n\ <div id="">这里其实是一个时间差,比如指定的好友3天留言一次,今天是4月10日,你就选择4月13日就行了,这样做方便一点</div>\n\ <div class="layui-form">\n\ <div class="layui-form-item">\n\ <div class="layui-inline" style="opacity:0;filter: alpha(opacity=0);position: absolute;z-index: 0;">\n\ <label class="layui-form-label">请选择留言</label> <!--这个是被点击对象,隐藏、不占空间、触发事件-->\n\ <div class="layui-input-inline">\n\ <input type="text" class="layui-input" id="test-limit2" readonly="" placeholder="yyyy-MM-dd">\n\ </div>\n\ </div>\n\ <div class="layui-inline" style="position: relative;z-index: -1;">\n\ <label class="layui-form-label">留言日期差</label> <!--这个是克隆出来的对象,显示,占空间、被覆盖,不触发事件-->\n\ <div class="layui-input-inline">\n\ <input type="text" class="layui-input" id="test-limit1" readonly="" placeholder="yyyy-MM-dd">\n\ </div>\n\ </div>\n\ \n\ </div>\n\ </div>\n\ <div style="margin-left: 5px;vertical-align: top;margin-top:5px;">\n\ <span>\n\ <button id="setTimeInterval">为选择的好友设置留言时间间隔</button>\n\ </span>\n\ <span>\n\ <button id="unsetTimeInterval">为选择的好友取消设置留言时间间隔</button>\n\ </span>\n\ </div>\n\ \n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置自动留言计划:</legend>\n\ </fieldset>\n\ <div class="layui-form">\n\ <div class="layui-form-item">\n\ <div class="layui-inline" style="opacity:0;filter: alpha(opacity=0);position: absolute;z-index: 0;">\n\ <label class="layui-form-label">请选择时间</label> <!--这个是被点击对象,隐藏、不占空间、触发事件-->\n\ <div class="layui-input-inline">\n\ <input type="text" class="layui-input" id="test14" placeholder="H时m分s秒">\n\ </div>\n\ </div>\n\ <div class="layui-inline" style="position: relative;z-index: -1;">\n\ <label class="layui-form-label">请选择时间</label> <!--这个是克隆出来的对象,显示,占空间、被覆盖,不触发事件-->\n\ <div class="layui-input-inline">\n\ <input type="text" class="layui-input" id="test15" placeholder="H时m分s秒">\n\ </div>\n\ </div>\n\ </div>\n\ </div>\n\ \n\ <table class="layui-hide" id="test" lay-filter="test"></table> <!-- 数据表格 -->\n\ \n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置好友分组:</legend>\n\ </fieldset>\n\ <div style="margin-left: 5px;vertical-align: top;margin-top:5px;">\n\ \n\ <form class="layui-form" action="">\n\ <div class="layui-form-item">\n\ <div class="layui-inline">\n\ <label class="layui-form-label">分组列表</label>\n\ <div class="layui-input-inline">\n\ <select name="modules" lay-verify="required" lay-search="">\n\ <option value="">直接选择或搜索选择</option>\n\ <option value="1">分组名称</option>\n\ <option value="2">分组名称</option>\n\ <option value="3">分组名称</option>\n\ <option value="4">分组名称</option>\n\ <option value="5">分组名称</option>\n\ <option value="6">分组名称</option>\n\ <option value="7">分组名称</option>\n\ <option value="8">分组名称</option>\n\ <option value="9">分组名称</option>\n\ </select>\n\ </div>\n\ <button type="button" class="layui-btn" id="editFriendGroup">编辑列表</button>\n\ </div>\n\ </div>\n\ </form>\n\ \n\ <span>\n\ <button id="addFriendToGroup">为选择的好友添加分组</button>\n\ </span>\n\ <span>\n\ <button id="unaddFriendToGroup">为选择的好友取消添加分组</button>\n\ </span>\n\ \n\ <div class="layui-collapse" lay-filter="test">\n\ <div class="layui-colla-item">\n\ <h2 class="layui-colla-title">分组名称</h2>\n\ <div class="layui-colla-content">\n\ <p>用户</p>\n\ <p>用户</p>\n\ <p>用户</p>\n\ </div>\n\ </div>\n\ <div class="layui-colla-item">\n\ <h2 class="layui-colla-title">分组名称</h2>\n\ <div class="layui-colla-content">\n\ <p>用户</p>\n\ <p>用户</p>\n\ </p>\n\ </div>\n\ </div>\n\ <div class="layui-colla-item">\n\ <h2 class="layui-colla-title">分组名称</h2>\n\ <div class="layui-colla-content">\n\ <p>用户</p>\n\ <p>用户</p>\n\ </div>\n\ </div>\n\ <div class="layui-colla-item">\n\ <h2 class="layui-colla-title">分组名称</h2>\n\ <div class="layui-colla-content">\n\ <p>用户</p>\n\ </div>\n\ </div>\n\ </div>\n\ \n\ </div>\n\ </div>\n\ <div id="laydateDemo"></div>\n\ <div id="log1">\n\ <span id="log_head1"></span>\n\ <span id="log_body1" style="display:inline-block;width:100%;overflow: hidden;white-space: nowrap;text-overflow: ellipsis; /*超出部分用...代替*/"></span>\n\ </div>\n\ </div>\n\ \n\ <div class="layui-tab-item" style="background-color: rgba(0,0,0,0.2); color: #ebebeb;">\n\ \n\ <span style="margin-left: 5px;vertical-align: top;">\n\ <button id="NationalityGroup">按国籍进行高亮分组</button>\n\ </span>\n\ <span style="margin-left: 5px;vertical-align: top;">\n\ <button id="NationalitySortGroup">按国籍进行排序分组(慢)</button>\n\ </span>\n\ <span style="margin-left: 5px;vertical-align: top;">\n\ <button id="OfflineTimeGroup">按在线时间进行排序分组</button>\n\ </span>\n\ <span style="margin-left: 5px;vertical-align: top;">\n\ <button id="ShowFriendData">显示好友详细数据-不可用</button>\n\ </span>\n\ <div class="layui-tab" lay-filter="test1">\n\ <ul class="layui-tab-title">\n\ <li class="layui-this" lay-id="11" style="color:#ebebeb;">好友数据统计</li>\n\ <li lay-id="22" style="color:#ebebeb;">留言数据统计</li>\n\ <li lay-id="33" style="color:#ebebeb;">关系网统计</li>\n\ <li lay-id="44" style="color:#ebebeb;">当前配置统计</li>\n\ <li lay-id="55" style="color:#ebebeb;">查看好友配置统计</li>\n\ </ul>\n\ <div class="layui-tab-content">\n\ <div class="layui-tab-item layui-show">\n\ <span>数据表格(汇总所有的数据:id,名称,备注,国籍(语言),等级,好友数量,游戏数量,dlc数量,创意工坊数量,艺术作品数量,动态数量)</span>\n\ <table class="layui-hide" id="friendStatistics" lay-filter="friendStatistics"></table> <!--数据表格-->\n\ <div id="container_friendStatistics" style="width: 600px;height:400px;"></div>\n\ </div>\n\ <div class="layui-tab-item">\n\ <span>分为:</span>\n\ <span>按国籍的饼图(总留言数量),</span>\n\ <span>按每天留言数据的折线图(统计所有的留言数据,生成的折线图),</span>\n\ <span>按最多留言数据的柱状图(那些好友一天留言数量排行榜/那些好友总留言数量排行榜/累计连续每天留言数量最多),</span>\n\ <span>数据表格(汇总所有的数据)</span>\n\ <div id="container_commentStatistics" style="min-width:400px;height:400px"></div>\n\ </div>\n\ <div class="layui-tab-item">\n\ <span>好友关系网(仅统计共同好友)</span>\n\ <div id="container_relationshipStatistics" style="min-width: 320px;max-width: 800px;margin: 0 auto;"></div>\n\ </div>\n\ <div class="layui-tab-item">\n\ <span>当前的配置数据和运行状态<span>\n\ <div id="container_currConfStatistics"></div>\n\ </div>\n\ <div class="layui-tab-item">\n\ <span>对好友设置的配置数据(比如国籍,不留言,留言时间间隔等)</span>\n\ <div id="container_friConfStatistics"></div>\n\ </div>\n\ </div>\n\ </div>\n\ \n\ <div id="pageDemo"></div>\n\ </div>\n\ \n\ <div class="layui-tab-item" style="background-color: rgba(0,0,0,0.2); color: #ebebeb;">\n\ <fieldset class="layui-elem-field">\n\ <legend>动态点赞助手</legend>\n\ <form class="layui-form" action="" lay-filter="example">\n\ <div class="layui-form-item" pane="">\n\ <label class="layui-form-label">总开关</label>\n\ <div class="layui-input-block">\n\ <!-- checked="" -->\n\ <input type="checkbox" name="close" lay-skin="switch" lay-filter="switchTest" title="开关" lay-text="开启|关闭" id="friendActivitySwitch">\n\ </div>\n\ </div>\n\ </form>\n\ <div class="layui-field-box">\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置点赞内容:</legend>\n\ </fieldset>\n\ <form class="layui-form" action="">\n\ <div class="layui-form-item">\n\ <label class="layui-form-label">点赞内容:</label>\n\ <div class="layui-row">\n\ <div class="layui-input-block">\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[1]" lay-skin="primary" title="朋友发布了状态" checked=""><br>\n\ <input type="checkbox" name="like[2]" lay-skin="primary" title="朋友发布了评测" checked=""><br>\n\ <input type="checkbox" name="like[3]" lay-skin="primary" title="朋友购买了游戏或者DLC" checked=""><br>\n\ <input type="checkbox" name="like[4]" lay-skin="primary" title="组发布了通知" checked=""><br>\n\ <input type="checkbox" name="like[5]" lay-skin="primary" title="组发布了活动" checked=""><br>\n\ </div>\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[6]" lay-skin="primary" title="朋友发布了艺术作品" checked=""><br>\n\ <input type="checkbox" name="like[7]" lay-skin="primary" title="朋友发布了创意工坊作品" checked=""><br>\n\ <input type="checkbox" name="like[8]" lay-skin="primary" title="朋友发布了指南" checked=""><br>\n\ <input type="checkbox" name="like[9]" lay-skin="primary" title="朋友上传了载图" checked=""><br>\n\ <input type="checkbox" name="like[10]" lay-skin="primary" title="朋友上传了视频" checked=""><br>\n\ </div>\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[11]" lay-skin="primary" title="朋友收藏了艺术作品" checked=""><br>\n\ <input type="checkbox" name="like[12]" lay-skin="primary" title="朋友收藏了创意工坊作品" checked=""><br>\n\ <input type="checkbox" name="like[13]" lay-skin="primary" title="朋友收藏了指南" checked=""><br>\n\ <input type="checkbox" name="like[14]" lay-skin="primary" title="朋友收藏了载图" checked=""><br>\n\ <input type="checkbox" name="like[15]" lay-skin="primary" title="朋友收藏了视频" checked=""><br>\n\ </div>\n\ </div>\n\ </div>\n\ </div>\n\ </form>\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置自动点赞模式:</legend>\n\ </fieldset>\n\ <form class="layui-form" action="">\n\ <div class="layui-form-item">\n\ <label class="layui-form-label">点赞模式:</label>\n\ <div class="layui-input-block">\n\ <input type="checkbox" name="like[1]" lay-skin="primary" title="运行后自动开始点赞" checked=""><br>\n\ <input type="checkbox" name="like[2]" lay-skin="primary" title="点赞完成后自动刷新并点赞新动态时间间隔" checked=""><br>\n\ </div>\n\ </div>\n\ </form>\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置自动点赞时间区间(默认今天~之前所有的动态内容)</legend>\n\ </fieldset>\n\ <div class="layui-form">\n\ <div class="layui-form-item">\n\ <div class="layui-inline">\n\ <label class="layui-form-label">请选择范围</label>\n\ <div class="layui-input-inline">\n\ <input type="text" class="layui-input" id="test-limit3" readonly="" placeholder=" ~ "> <!--placeholder="yyyy-MM-dd"-->\n\ </div>\n\ </div>\n\ </div>\n\ </div>\n\ <fieldset class="layui-elem-field layui-field-title" style="margin-top: 30px;">\n\ <legend style="color:#66ccff;">点赞进度时间线</legend>\n\ </fieldset>\n\ <ul class="layui-timeline">\n\ <li class="layui-timeline-item">\n\ <i class="layui-icon layui-timeline-axis"></i>\n\ <div class="layui-timeline-content layui-text">\n\ <h3 class="layui-timeline-title" style="color:#66ccff;">8月18日</h3>\n\ <p style="color:#fff;">\n\ <span>已点赞状态x条,点赞发布艺术作品x条,点赞收藏艺术作品x条</span>\n\ <br><span>已点赞评测x条,点赞发布创意工坊x条,点赞收藏创意工坊x条</span>\n\ <br><span>已点赞购买状态x条,点赞发布指南x条,点赞收藏指南x条</span>\n\ <br><span>已点赞组通知x条,点赞上次载图x条,点赞收藏载图x条</span>\n\ <br><span>已点赞组活动x条,点赞上传视频x条,点赞收藏视频x条</span>\n\ </p>\n\ </div>\n\ </li>\n\ <li class="layui-timeline-item">\n\ <i class="layui-icon layui-timeline-axis"></i>\n\ <div class="layui-timeline-content layui-text">\n\ <h3 class="layui-timeline-title" style="color:#66ccff;">8月16日</h3>\n\ <p style="color:#fff;">杜甫的思想核心是儒家的仁政思想,他有"致君尧舜上,再使风俗淳"的宏伟抱负。个人最爱的名篇有:</p>\n\ <ul style="color:#fff;">\n\ <li>《登高》</li>\n\ <li>《茅屋为秋风所破歌》</li>\n\ </ul>\n\ </div>\n\ </li>\n\ <li class="layui-timeline-item">\n\ <i class="layui-icon layui-timeline-axis"></i>\n\ <div class="layui-timeline-content layui-text">\n\ <h3 class="layui-timeline-title" style="color:#66ccff;">8月15日</h3>\n\ <p style="color:#fff;">\n\ <span>中国人民抗日战争胜利日</span>\n\ <br><span>常常在想,尽管对这个国家有这样那样的抱怨,但我们的确生在了最好的时代</span>\n\ <br><span>铭记、感恩</span>\n\ <br><span>所有为中华民族浴血奋战的英雄将士</span>\n\ <br><span>永垂不朽</span>\n\ </p>\n\ </div>\n\ </li>\n\ <li class="layui-timeline-item">\n\ <i class="layui-icon layui-timeline-axis"></i>\n\ <div class="layui-timeline-content layui-text">\n\ <div class="layui-timeline-title" style="color:#66ccff;">过去</div>\n\ </div>\n\ </li>\n\ </ul>\n\ </div>\n\ </fieldset>\n\ </div>\n\ \n\ <div class="layui-tab-item" style="background-color: rgba(0,0,0,0.2); color: #ebebeb;">\n\ <fieldset class="layui-elem-field">\n\ <legend>喜加一助手</legend>\n\ <div class="layui-field-box">\n\ <!-- <div>是否启动喜加一助手</div> -->\n\ <form class="layui-form" action="" lay-filter="example">\n\ <div class="layui-form-item" pane="">\n\ <label class="layui-form-label">总开关</label>\n\ <div class="layui-input-block">\n\ <!-- checked="" -->\n\ <input type="checkbox" name="close" lay-skin="switch" lay-filter="switchTest2" title="开关" lay-text="开启|关闭" id="FreeGameSwitch">\n\ </div>\n\ </div>\n\ </form>\n\ <form class="layui-form" action="">\n\ <div class="layui-form-item">\n\ <label class="layui-form-label">设置:</label>\n\ <div class="layui-row">\n\ <div class="layui-input-block">\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[1]" lay-skin="primary" title="自动获取喜加一信息" checked=""><br>\n\ </div>\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[6]" lay-skin="primary" title="自动领取喜加一游戏" checked=""><br>\n\ </div>\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[11]" lay-skin="primary" title="置顶显示在上方" checked=""><br>\n\ </div>\n\ </div>\n\ </div>\n\ </div>\n\ </form>\n\ \n\ <div>设置喜加一数据来源</div>\n\ <form class="layui-form" action="">\n\ <div class="layui-form-item">\n\ <label class="layui-form-label">设置:</label>\n\ <div class="layui-row">\n\ <div class="layui-input-block">\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[1]" lay-skin="primary" title="SteamDB" checked=""><br>\n\ </div>\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[6]" lay-skin="primary" title="humblebundle" disabled=""><br>\n\ </div>\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[11]" lay-skin="primary" title="fanatical" disabled=""><br>\n\ </div>\n\ </div>\n\ </div>\n\ </div>\n\ </form>\n\ </div>\n\ </fieldset>\n\ </div>\n\ \n\ <div class="layui-tab-item" style="background-color: rgba(0,0,0,0.2); color: #ebebeb;">\n\ <fieldset class="layui-elem-field">\n\ <legend>功能设置</legend>\n\ <div class="layui-field-box">\n\ \n\ <form class="layui-form" action="" lay-filter="example">\n\ <div class="layui-form-item" pane="">\n\ <label class="layui-form-label">Debug模式</label>\n\ <div class="layui-input-block">\n\ <!-- checked="" -->\n\ <input type="checkbox" name="close" lay-skin="switch" lay-filter="switchTest3" title="开关" lay-text="开启|关闭">\n\ </div>\n\ </div>\n\ </form>\n\ <div>弹出层</div>\n\ <div>滑块</div>\n\ <button type="button" class="layui-btn">导入导出重置当前设置</button>\n\ <div>弹出层</div>\n\ \n\ <div class="layui-upload-drag" id="uploadDemo">\n\ <i class="layui-icon"></i>\n\ <p>点击上传,或将文件拖拽到此处</p>\n\ <div class="layui-hide" id="uploadDemoView">\n\ <hr>\n\ <img src="" alt="上传成功后渲染" style="max-width: 100%">\n\ </div>\n\ </div>\n\ </div>\n\ </fieldset>\n\ \n\ <fieldset class="layui-elem-field">\n\ <legend>界面设置</legend>\n\ <div class="layui-field-box">\n\ \n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>语言配置</legend>\n\ <div id="selectLanguageDropdown" class="localizationTool"></div>\n\ <button type="button" class="layui-btn">自动检测(简体中文)</button>\n\ <button type="button" class="layui-btn">简体中文</button>\n\ <button type="button" class="layui-btn">繁体中文</button>\n\ <button type="button" class="layui-btn">English</button>\n\ </fieldset>\n\ \n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>主题切换</legend>\n\ <div>请选择一个主题,然后点击应用</div>\n\ <button type="button" class="layui-btn">应用主题</button>\n\ </fieldset>\n\ \n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>UI设置</legend>\n\ <div>预览:</div>\n\ <div>\n\ <span>主要字体颜色:<span>\n\ <span style="margin-left: 30px;">\n\ <input type="hidden" name="color" value="" id="test-all-input">\n\ <div id="test-all1"></div>\n\ </span>\n\ </div>\n\ \n\ <div>\n\ <span>主要背景颜色:</span>\n\ <span style="margin-left: 30px;">\n\ <input type="hidden" name="color" value="" id="test-all-input">\n\ <div id="test-all2"></div>\n\ </span>\n\ </div>\n\ \n\ <div>\n\ <span>留言成功字体颜色:<span>\n\ <span style="margin-left: 30px;">\n\ <input type="hidden" name="color" value="" id="test-all-input">\n\ <div id="test-all3"></div>\n\ </span>\n\ </div>\n\ \n\ <div>\n\ <span>留言失败字体颜色:</span>\n\ <span style="margin-left: 30px;">\n\ <input type="hidden" name="color" value="" id="test-all-input">\n\ <div id="test-all4"></div>\n\ </span>\n\ </div>\n\ \n\ <div>\n\ <span>留言发生错误字体颜色:</span>\n\ <span style="margin-left: 30px;">\n\ <input type="hidden" name="color" value="" id="test-all-input">\n\ <div id="test-all5"></div>\n\ </span>\n\ </div>\n\ \n\ <button type="button" class="layui-btn">保存为主题</button>\n\ </fieldset>\n\ \n\ </div>\n\ </fieldset>\n\ \n\ <fieldset class="layui-elem-field">\n\ <legend>关于SteamAssistant(Steam小助手)</legend>\n\ <div class="layui-field-box">\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>程序信息:</legend>\n\ <div>当前版本:v0.2.3.0</div>\n\ <div>主程序框架更新时间:2020年4月19日</div>\n\ <div>common模块:2020年4月19日</div>\n\ <div>databaseConf模块:2020年4月19日</div>\n\ <div>externalApis模块:2020年4月19日</div>\n\ <div>steamApis模块:2020年4月19日</div>\n\ <div>translateApis模块:2020年4月19日</div>\n\ <div>Utility模块:2020年4月19日</div>\n\ <div>UI模块:2020年4月19日</div>\n\ <div>Event模块:2020年4月19日</div>\n\ <div>CityList模块:2020年4月19日</div>\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>联系作者:</legend>\n\ <button type="button" class="layui-btn">反馈错误</button>\n\ <button type="button" class="layui-btn">提交建议</button>\n\ </div>\n\ </fieldset>\n\ \n\ <div id="sliderDemo" style="margin: 50px 20px;"></div>\n\ </div>\n\ \n\ </div>\n\ </div>\n\ '; var loadUI_Html = '\ <div class="text-wrapper">\n\ <div class="text part1">\n\ <div>\n\ <span class="letter">\n\ <div class="localTool-3-1 character">L</div>\n\ <span></span>\n\ </span>\n\ \n\ <span class="letter">\n\ <div class="character">o</div>\n\ <span></span>\n\ </span>\n\ \n\ <span class="letter">\n\ <div class="character">a</div>\n\ <span></span>\n\ </span>\n\ \n\ <span class="letter">\n\ <div class="character">d</div>\n\ <span></span>\n\ </span>\n\ \n\ <span class="letter">\n\ <div class="character">i</div>\n\ <span></span>\n\ </span>\n\ \n\ <span class="letter">\n\ <div class="character">n</div>\n\ <span></span>\n\ </span>\n\ \n\ <span class="letter">\n\ <div class="character">g</div>\n\ <span></span>\n\ </span>\n\ </div>\n\ </div>\n\ <div class="how-to"><span>正在加载资源中,已完成0/10,请您耐心等待...</span></div>\n\ </div>\n\ '; var mainUI_html = '\ <div class="layui-tab layui-tab-brief" lay-filter="demo">\n\ <ul class="layui-tab-title" style="color: #ebebeb;">\n\ <li class="localTool-4-1 layui-this">留言</li>\n\ <li>留言设置</li>\n\ <li>数据分析</li>\n\ <li>点赞助手</li>\n\ <li>拓展功能(测试)</li>\n\ <li>设置</li>\n\ </ul>\n\ <div class="layui-tab-content">\n\ <div class="layui-tab-item layui-show" style="color: #ebebeb;">\n\ <!----------------------------------------------------------------------------------------------------------------->\n\ <div class="commentthread_entry">\n\ <div class="commentthread_entry_quotebox">\n\ <!--<textarea class="commentthread_textarea" id="comment_textarea" onfocus="this.focus();this.select();inBoxShrinkage(\'comment_textarea\',false);" onClick="" onblur="inBoxonblurID=0;inBoxShrinkage(\'comment_textarea\',true);" placeholder="添加留言" style="overflow: hidden; height: 28px;"></textarea>-->\n\ <textarea class="commentthread_textarea" id="comment_textarea" onfocus="inBoxonblurID=0;inBoxShrinkage(\'comment_textarea\',false);" onClick="" onblur="inBoxonblurID=0;inBoxShrinkage(\'comment_textarea\',true);" placeholder="添加留言" style="overflow: hidden; height: 28px;"></textarea>\n\ </div>\n\ \n\ <form class="layui-form" action="" lay-filter="example">\n\ <div id="strInBytes" style="color: #32CD32;display: inline-block;font-family: Consolas;font-size: 16px;">\n\ <span>当前字符字节数: </span>\n\ <span id="strInBytes_Text">0</span>\n\ <span>/999</span>\n\ </div>\n\ <div class="layui-inline">\n\ <label class="layui-form-label" style="width: auto;">文本格式(直接添加或选择文字添加)</label>\n\ <div class="layui-input-inline">\n\ <select name="modules" lay-verify="required" lay-search="" id="steamTextStyle">\n\ <option value="">直接选择或搜索选择</option>\n\ <option value="1">[h1]标题文字[/h1]</option>\n\ <option value="2">[b]粗体文本[/b]</option>\n\ <option value="3">[u]下划线文本[/u]</option>\n\ <option value="4">[i]斜体文本[/i]</option>\n\ <option value="5">[strike]删除文本[/strike]</option>\n\ <option value="6">[spoiler]隐藏文本[/spoiler]</option>\n\ <option value="7">[noparse]不解析[b]标签[/b][/noparse]</option>\n\ <option value="8">[url=store.steampowered.com]网站链接[/url]</option>\n\ </select>\n\ </div>\n\ <button type="button" class="layui-btn layui-btn-normal" id="LAY-component-form-getval">添加</button>\n\ </div>\n\ </form>\n\ \n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>翻译模块(需要提前设置国籍):</legend>\n\ </fieldset>\n\ <div id="translationOptions" style="color:#fff;">\n\ <span><span>当前语言:</span> \n\ <select id="origLanguageSelectBox" style="padding: 4px 12px 4px 8px;font-size:12px;outline:0;border: 1px solid #34DEFF;background-color:transparent;color: #66ccff;">\n\ <option name="auto" value="auto" style="color:#fff;background-color: #3E9AC6;">自动检测</option>\n\ <option name="zhc" value="zh-CN" style="color:#fff;background-color: #3E9AC6;">中文简体</option>\n\ <option name="en" value="en" style="color:#fff;background-color: #3E9AC6;">英语</option>\n\ <option name="jp" value="ja" style="color:#fff;background-color: #3E9AC6;">日语</option>\n\ </select>\n\ </span>\n\ \n\ <span style="margin-left: 5px;"><span>目标语言: </span>\n\ <select id="selectBoxID" class="selectBox" multiple="multiple">\n\ <option value="en">英语</option>\n\ <option value="ja">日语</option>\n\ <option value="zh-CN">中文简体</option>\n\ <option value="zh-sg">马新简体[zh-sg]</option>\n\ <option value="zh-hant">繁體中文[zh-hant]</option>\n\ <option value="zh-hk">繁體中文(香港)[zh-hk]</option>\n\ <option value="zh-mo">繁體中文(澳门)[zh-mo]</option>\n\ <option value="zh-tw">繁體中文(台湾)[zh-tw]</option>\n\ </select>\n\ </span>\n\ \n\ <span style="margin-left: 5px;vertical-align: middle;">\n\ <button id="translationText">翻译</button>\n\ </span>\n\ </div>\n\ \n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>添加称呼模块(需要提前设置备注):</legend>\n\ </fieldset>\n\ <div class="commentthread_entry_submitlink" style="">\n\ <span class="isCustom" style="display: block;text-align: left;">\n\ <!-- 默认为{name},可以自行修改,好友没有备注则使用steam名称 -->\n\ <span style="font-size:14px;line-height: 20px;color: #67c1f5 !important;">自定义称呼模式</span>\n\ <input class="nameAddType" id="select_isCustom_checkbox" name="nameAddType" type="radio" style="vertical-align: middle;margin:2px;">\n\ <span style="margin-left: 5px;vertical-align: middle;">\n\ <button id="addCustomName">在留言框添加自定义称呼标识符</button>\n\ </span>\n\ </span>\n\ \n\ <span class="isName" style="display: block;text-align: left;">\n\ <span style="font-size:14px;line-height: 20px;color: #67c1f5 !important;">是否为好友添加称呼(如果好友没有备注则使用steam名称)</span>\n\ <input class="nameAddType" id="select_islName_checkbox" name="nameAddType" type="radio" style="vertical-align: middle;margin:2px;">\n\ </span>\n\ \n\ <span class="isSpecialName" style="display: block;text-align: left;">\n\ <span style="font-size:14px;line-height: 20px;color: #67c1f5 !important;">是否为好友添加称呼(如果好友设置有备注则使用,否则不添加称呼)</span>\n\ <input class="nameAddType" id="select_isSpecialName_checkbox" name="nameAddType" type="radio" style="vertical-align: middle;margin:2px;">\n\ </span>\n\ \n\ <fieldset class="layui-elem-field layui-field-title" style="padding: 10px 0px;">\n\ <span style="display: block;text-align: right;">\n\ <a class="btn_grey_black btn_small_thin" href="javascript:CCommentThread.FormattingHelpPopup( \'Profile\' );">\n\ <span class="btn_grey_black btn_small_thin_text">格式化帮助</span>\n\ </a>\n\ \n\ <span class="emoticon_container">\n\ <span class="emoticon_button small" id="emoticonbtn"></span>\n\ </span>\n\ \n\ <span class="btn_green_white_innerfade btn_small" id="comment_submit">\n\ <span id="comment_submit_text">发送评论给选择的好友</span>\n\ </span>\n\ \n\ <span class="btn_green_white_innerfade btn_small" id="comment_submit_special">\n\ <span id="comment_submit_special_text">根据国籍发送评论给选择的好友</span>\n\ </span>\n\ </span>\n\ </div>\n\ </div>\n\ <div id="log">\n\ <span id="log_head"></span>\n\ <span id="log_body" style="display:inline-block;width:100%;overflow: hidden;white-space: nowrap;text-overflow: ellipsis; /*超出部分用...代替*/"></span>\n\ </div>\n\ <!----------------------------------------------------------------------------------------------------------------->\n\ \n\ </div>\n\ \n\ <div class="layui-tab-item" style="background-color: rgba(0,0,0,0.2); color: #ebebeb;">\n\ <div style="text-align: left;margin: 5px 0px;">\n\ <span style="margin-left: 5px;vertical-align: middle;">\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置国籍:</legend>\n\ </fieldset>\n\ <div style="color: #67c1f5;">请选择要设置的国籍:</div>\n\ <select id="nationalitySelectBox" style="padding: 4px 12px 4px 8px;font-size:12px;outline:0;border: 1px solid #34DEFF;background-color:transparent;color: #66ccff;">\n\ <option name="CN" value="CN" style="color:#fff;background-color: #3E9AC6;">简体中文</option>\n\ <option name="EN" value="EN" style="color:#fff;background-color: #3E9AC6;">英语</option>\n\ <option name="JP" value="JP" style="color:#fff;background-color: #3E9AC6;">日语</option>\n\ <option name="CN-SG" value="CN-SG" style="color:#fff;background-color: #3E9AC6;">马新简体(马来西亚,新加坡)[zh-sg]</option>\n\ <option name="CN-HANT" value="CN-HANT" style="color:#fff;background-color: #3E9AC6;">繁體中文[zh-hant]</option>\n\ <option name="CN-HK" value="CN-HK" style="color:#fff;background-color: #3E9AC6;">繁體中文(香港)[zh-hk]</option>\n\ <option name="CN-MO" value="CN-MO" style="color:#fff;background-color: #3E9AC6;">繁體中文(澳门)[zh-mo]</option>\n\ <option name="CN-TW" value="CN-TW" style="color:#fff;background-color: #3E9AC6;">繁體中文(台湾)[zh-tw]</option>\n\ </select>\n\ <button id="setNationality">为选择的好友设置国籍标识</button>\n\ </span>\n\ <span style="margin-left: 5px;vertical-align: top;">\n\ <button id="unsetNationality">为选择的好友取消国籍标识</button>\n\ </span>\n\ <br />\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置不留言:</legend>\n\ </fieldset>\n\ <div style="margin-left: 5px;vertical-align: top;margin-top:5px;">\n\ <span>\n\ <button id="setNoLeave">为选择的好友设置不留言</button>\n\ </span>\n\ <span>\n\ <button id="unsetNoLeave">为选择的好友取消设置不留言</button>\n\ </span>\n\ </div>\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置留言时间间隔:</legend>\n\ </fieldset>\n\ <div id="">只选择日期则过n天后再留言,只选择时间则过x时后再留言(严格模式),日期和时间都选择了则过n天x时后再留言(严格模式)</div>\n\ <div id="">这里其实是一个时间差,比如指定的好友3天留言一次,今天是4月10日,你就选择4月13日就行了,这样做方便一点</div>\n\ <div class="layui-form">\n\ <div class="layui-form-item">\n\ <div class="layui-inline" style="opacity:0;filter: alpha(opacity=0);position: absolute;z-index: 0;">\n\ <label class="layui-form-label">请选择留言</label> <!--这个是被点击对象,隐藏、不占空间、触发事件-->\n\ <div class="layui-input-inline">\n\ <input type="text" class="layui-input" id="test-limit2" readonly="" placeholder="yyyy-MM-dd">\n\ </div>\n\ </div>\n\ <div class="layui-inline" style="position: relative;z-index: -1;">\n\ <label class="layui-form-label">留言日期差</label> <!--这个是克隆出来的对象,显示,占空间、被覆盖,不触发事件-->\n\ <div class="layui-input-inline">\n\ <input type="text" class="layui-input" id="test-limit1" readonly="" placeholder="yyyy-MM-dd">\n\ </div>\n\ </div>\n\ \n\ </div>\n\ </div>\n\ <div style="margin-left: 5px;vertical-align: top;margin-top:5px;">\n\ <span>\n\ <button id="setTimeInterval">为选择的好友设置留言时间间隔</button>\n\ </span>\n\ <span>\n\ <button id="unsetTimeInterval">为选择的好友取消设置留言时间间隔</button>\n\ </span>\n\ </div>\n\ \n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置自动留言计划:</legend>\n\ </fieldset>\n\ <div class="layui-form">\n\ <div class="layui-form-item">\n\ <div class="layui-inline" style="opacity:0;filter: alpha(opacity=0);position: absolute;z-index: 0;">\n\ <label class="layui-form-label">请选择时间</label> <!--这个是被点击对象,隐藏、不占空间、触发事件-->\n\ <div class="layui-input-inline">\n\ <input type="text" class="layui-input" id="test14" placeholder="H时m分s秒">\n\ </div>\n\ </div>\n\ <div class="layui-inline" style="position: relative;z-index: -1;">\n\ <label class="layui-form-label">请选择时间</label> <!--这个是克隆出来的对象,显示,占空间、被覆盖,不触发事件-->\n\ <div class="layui-input-inline">\n\ <input type="text" class="layui-input" id="test15" placeholder="H时m分s秒">\n\ </div>\n\ </div>\n\ </div>\n\ </div>\n\ \n\ <table class="layui-hide" id="test" lay-filter="test"></table> <!-- 数据表格 -->\n\ \n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置好友分组:</legend>\n\ </fieldset>\n\ <div style="margin-left: 5px;vertical-align: top;margin-top:5px;">\n\ \n\ <form class="layui-form" action="">\n\ <div class="layui-form-item">\n\ <div class="layui-inline">\n\ <label class="layui-form-label">分组列表</label>\n\ <div class="layui-input-inline">\n\ <select name="modules" lay-verify="required" lay-search="">\n\ <option value="">直接选择或搜索选择</option>\n\ <option value="1">分组名称</option>\n\ <option value="2">分组名称</option>\n\ <option value="3">分组名称</option>\n\ <option value="4">分组名称</option>\n\ <option value="5">分组名称</option>\n\ <option value="6">分组名称</option>\n\ <option value="7">分组名称</option>\n\ <option value="8">分组名称</option>\n\ <option value="9">分组名称</option>\n\ </select>\n\ </div>\n\ <button type="button" class="layui-btn" id="editFriendGroup">编辑列表</button>\n\ </div>\n\ </div>\n\ </form>\n\ \n\ <span>\n\ <button id="addFriendToGroup">为选择的好友添加分组</button>\n\ </span>\n\ <span>\n\ <button id="unaddFriendToGroup">为选择的好友取消添加分组</button>\n\ </span>\n\ \n\ <div class="layui-collapse" lay-filter="test">\n\ <div class="layui-colla-item">\n\ <h2 class="layui-colla-title">分组名称</h2>\n\ <div class="layui-colla-content">\n\ <p>用户</p>\n\ <p>用户</p>\n\ <p>用户</p>\n\ </div>\n\ </div>\n\ <div class="layui-colla-item">\n\ <h2 class="layui-colla-title">分组名称</h2>\n\ <div class="layui-colla-content">\n\ <p>用户</p>\n\ <p>用户</p>\n\ </p>\n\ </div>\n\ </div>\n\ <div class="layui-colla-item">\n\ <h2 class="layui-colla-title">分组名称</h2>\n\ <div class="layui-colla-content">\n\ <p>用户</p>\n\ <p>用户</p>\n\ </div>\n\ </div>\n\ <div class="layui-colla-item">\n\ <h2 class="layui-colla-title">分组名称</h2>\n\ <div class="layui-colla-content">\n\ <p>用户</p>\n\ </div>\n\ </div>\n\ </div>\n\ \n\ </div>\n\ </div>\n\ <div id="laydateDemo"></div>\n\ <div id="log1">\n\ <span id="log_head1"></span>\n\ <span id="log_body1" style="display:inline-block;width:100%;overflow: hidden;white-space: nowrap;text-overflow: ellipsis; /*超出部分用...代替*/"></span>\n\ </div>\n\ </div>\n\ \n\ <div class="layui-tab-item" style="background-color: rgba(0,0,0,0.2); color: #ebebeb;">\n\ \n\ <span style="margin-left: 5px;vertical-align: top;">\n\ <button id="NationalityGroup">按国籍进行高亮分组</button>\n\ </span>\n\ <span style="margin-left: 5px;vertical-align: top;">\n\ <button id="NationalitySortGroup">按国籍进行排序分组(慢)</button>\n\ </span>\n\ <span style="margin-left: 5px;vertical-align: top;">\n\ <button id="OfflineTimeGroup">按在线时间进行排序分组</button>\n\ </span>\n\ <span style="margin-left: 5px;vertical-align: top;">\n\ <button id="ShowFriendData">显示好友详细数据-不可用</button>\n\ </span>\n\ <div class="layui-tab" lay-filter="test1">\n\ <ul class="layui-tab-title">\n\ <li class="layui-this" lay-id="11" style="color:#ebebeb;">好友数据统计</li>\n\ <li lay-id="22" style="color:#ebebeb;">留言数据统计</li>\n\ <li lay-id="33" style="color:#ebebeb;">关系网统计</li>\n\ <li lay-id="44" style="color:#ebebeb;">当前配置统计</li>\n\ <li lay-id="55" style="color:#ebebeb;">查看好友配置统计</li>\n\ </ul>\n\ <div class="layui-tab-content">\n\ <div class="layui-tab-item layui-show">\n\ <span>数据表格(汇总所有的数据:id,名称,备注,国籍(语言),等级,好友数量,游戏数量,dlc数量,创意工坊数量,艺术作品数量,动态数量)</span>\n\ <table class="layui-hide" id="friendStatistics" lay-filter="friendStatistics"></table> <!--数据表格-->\n\ <div id="container_friendStatistics" style="width: 600px;height:400px;"></div>\n\ </div>\n\ <div class="layui-tab-item">\n\ <span>分为:</span>\n\ <span>按国籍的饼图(总留言数量),</span>\n\ <span>按每天留言数据的折线图(统计所有的留言数据,生成的折线图),</span>\n\ <span>按最多留言数据的柱状图(那些好友一天留言数量排行榜/那些好友总留言数量排行榜/累计连续每天留言数量最多),</span>\n\ <span>数据表格(汇总所有的数据)</span>\n\ <div id="container_commentStatistics" style="min-width:400px;height:400px"></div>\n\ </div>\n\ <div class="layui-tab-item">\n\ <span>好友关系网(仅统计共同好友)</span>\n\ <div id="container_relationshipStatistics" style="min-width: 320px;max-width: 800px;margin: 0 auto;"></div>\n\ </div>\n\ <div class="layui-tab-item">\n\ <span>当前的配置数据和运行状态</span>\n\ <div id="container_currConfStatistics"></div>\n\ </div>\n\ <div class="layui-tab-item">\n\ <span>对好友设置的配置数据(比如国籍,不留言,留言时间间隔等)</span>\n\ <div id="container_friConfStatistics"></div>\n\ </div>\n\ </div>\n\ </div>\n\ \n\ <div id="pageDemo"></div>\n\ </div>\n\ \n\ <div class="layui-tab-item" style="background-color: rgba(0,0,0,0.2); color: #ebebeb;">\n\ <fieldset class="layui-elem-field">\n\ <legend>动态点赞助手</legend>\n\ <form class="layui-form" action="" lay-filter="example">\n\ <div class="layui-form-item" pane="">\n\ <label class="layui-form-label">总开关</label>\n\ <div class="layui-input-block">\n\ <!-- checked="" -->\n\ <input type="checkbox" name="close" lay-skin="switch" lay-filter="switchTest" title="开关" lay-text="开启|关闭" id="friendActivitySwitch">\n\ </div>\n\ </div>\n\ </form>\n\ <div class="layui-field-box">\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置点赞内容:</legend>\n\ </fieldset>\n\ <form class="layui-form" action="">\n\ <div class="layui-form-item">\n\ <label class="layui-form-label">点赞内容:</label>\n\ <div class="layui-row">\n\ <div class="layui-input-block">\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[1]" lay-skin="primary" title="朋友发布了状态" checked=""><br>\n\ <input type="checkbox" name="like[2]" lay-skin="primary" title="朋友发布了评测" checked=""><br>\n\ <input type="checkbox" name="like[3]" lay-skin="primary" title="朋友购买了游戏或者DLC" checked=""><br>\n\ <input type="checkbox" name="like[4]" lay-skin="primary" title="组发布了通知" checked=""><br>\n\ <input type="checkbox" name="like[5]" lay-skin="primary" title="组发布了活动" checked=""><br>\n\ </div>\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[6]" lay-skin="primary" title="朋友发布了艺术作品" checked=""><br>\n\ <input type="checkbox" name="like[7]" lay-skin="primary" title="朋友发布了创意工坊作品" checked=""><br>\n\ <input type="checkbox" name="like[8]" lay-skin="primary" title="朋友发布了指南" checked=""><br>\n\ <input type="checkbox" name="like[9]" lay-skin="primary" title="朋友上传了载图" checked=""><br>\n\ <input type="checkbox" name="like[10]" lay-skin="primary" title="朋友上传了视频" checked=""><br>\n\ </div>\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[11]" lay-skin="primary" title="朋友收藏了艺术作品" checked=""><br>\n\ <input type="checkbox" name="like[12]" lay-skin="primary" title="朋友收藏了创意工坊作品" checked=""><br>\n\ <input type="checkbox" name="like[13]" lay-skin="primary" title="朋友收藏了指南" checked=""><br>\n\ <input type="checkbox" name="like[14]" lay-skin="primary" title="朋友收藏了载图" checked=""><br>\n\ <input type="checkbox" name="like[15]" lay-skin="primary" title="朋友收藏了视频" checked=""><br>\n\ </div>\n\ </div>\n\ </div>\n\ </div>\n\ </form>\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置自动点赞模式:</legend>\n\ </fieldset>\n\ <form class="layui-form" action="">\n\ <div class="layui-form-item">\n\ <label class="layui-form-label">点赞模式:</label>\n\ <div class="layui-input-block">\n\ <input type="checkbox" name="like[1]" lay-skin="primary" title="运行后自动开始点赞" checked=""><br>\n\ <input type="checkbox" name="like[2]" lay-skin="primary" title="点赞完成后自动刷新并点赞新动态时间间隔" checked=""><br>\n\ </div>\n\ </div>\n\ </form>\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>设置自动点赞时间区间(默认今天~之前所有的动态内容)</legend>\n\ </fieldset>\n\ <div class="layui-form">\n\ <div class="layui-form-item">\n\ <div class="layui-inline">\n\ <label class="layui-form-label">请选择范围</label>\n\ <div class="layui-input-inline">\n\ <input type="text" class="layui-input" id="test-limit3" readonly="" placeholder=" ~ "> <!--placeholder="yyyy-MM-dd"-->\n\ </div>\n\ </div>\n\ </div>\n\ </div>\n\ <fieldset class="layui-elem-field layui-field-title" style="margin-top: 30px;">\n\ <legend style="color:#66ccff;">点赞进度时间线</legend>\n\ </fieldset>\n\ <ul class="layui-timeline">\n\ <li class="layui-timeline-item">\n\ <i class="layui-icon layui-timeline-axis"></i>\n\ <div class="layui-timeline-content layui-text">\n\ <h3 class="layui-timeline-title" style="color:#66ccff;">8月18日</h3>\n\ <p style="color:#fff;">\n\ <span>已点赞状态x条,点赞发布艺术作品x条,点赞收藏艺术作品x条</span>\n\ <br><span>已点赞评测x条,点赞发布创意工坊x条,点赞收藏创意工坊x条</span>\n\ <br><span>已点赞购买状态x条,点赞发布指南x条,点赞收藏指南x条</span>\n\ <br><span>已点赞组通知x条,点赞上次载图x条,点赞收藏载图x条</span>\n\ <br><span>已点赞组活动x条,点赞上传视频x条,点赞收藏视频x条</span>\n\ </p>\n\ </div>\n\ </li>\n\ <li class="layui-timeline-item">\n\ <i class="layui-icon layui-timeline-axis"></i>\n\ <div class="layui-timeline-content layui-text">\n\ <h3 class="layui-timeline-title" style="color:#66ccff;">8月16日</h3>\n\ <p style="color:#fff;">杜甫的思想核心是儒家的仁政思想,他有"致君尧舜上,再使风俗淳"的宏伟抱负。个人最爱的名篇有:</p>\n\ <ul style="color:#fff;">\n\ <li>《登高》</li>\n\ <li>《茅屋为秋风所破歌》</li>\n\ </ul>\n\ </div>\n\ </li>\n\ <li class="layui-timeline-item">\n\ <i class="layui-icon layui-timeline-axis"></i>\n\ <div class="layui-timeline-content layui-text">\n\ <h3 class="layui-timeline-title" style="color:#66ccff;">8月15日</h3>\n\ <p style="color:#fff;">\n\ <span>中国人民抗日战争胜利日</span>\n\ <br><span>常常在想,尽管对这个国家有这样那样的抱怨,但我们的确生在了最好的时代</span>\n\ <br><span>铭记、感恩</span>\n\ <br><span>所有为中华民族浴血奋战的英雄将士</span>\n\ <br><span>永垂不朽</span>\n\ </p>\n\ </div>\n\ </li>\n\ <li class="layui-timeline-item">\n\ <i class="layui-icon layui-timeline-axis"></i>\n\ <div class="layui-timeline-content layui-text">\n\ <div class="layui-timeline-title" style="color:#66ccff;">过去</div>\n\ </div>\n\ </li>\n\ </ul>\n\ </div>\n\ </fieldset>\n\ </div>\n\ \n\ <div class="layui-tab-item" style="background-color: rgba(0,0,0,0.2); color: #ebebeb;">\n\ <fieldset class="layui-elem-field">\n\ <legend>喜加一助手</legend>\n\ <div class="layui-field-box">\n\ <!-- <div>是否启动喜加一助手</div> -->\n\ <form class="layui-form" action="" lay-filter="example">\n\ <div class="layui-form-item" pane="">\n\ <label class="layui-form-label">总开关</label>\n\ <div class="layui-input-block">\n\ <!-- checked="" -->\n\ <input type="checkbox" name="close" lay-skin="switch" lay-filter="switchTest2" title="开关" lay-text="开启|关闭" id="FreeGameSwitch">\n\ </div>\n\ </div>\n\ </form>\n\ <form class="layui-form" action="">\n\ <div class="layui-form-item">\n\ <label class="layui-form-label">设置:</label>\n\ <div class="layui-row">\n\ <div class="layui-input-block">\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[1]" lay-skin="primary" title="自动获取喜加一信息" checked=""><br>\n\ </div>\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[6]" lay-skin="primary" title="自动领取喜加一游戏" checked=""><br>\n\ </div>\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[11]" lay-skin="primary" title="置顶显示在上方" checked=""><br>\n\ </div>\n\ </div>\n\ </div>\n\ </div>\n\ </form>\n\ \n\ <div>设置喜加一数据来源</div>\n\ <form class="layui-form" action="">\n\ <div class="layui-form-item">\n\ <label class="layui-form-label">设置:</label>\n\ <div class="layui-row">\n\ <div class="layui-input-block">\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[1]" lay-skin="primary" title="SteamDB" checked=""><br>\n\ </div>\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[6]" lay-skin="primary" title="humblebundle" disabled=""><br>\n\ </div>\n\ <div class="layui-input-block" style="display:inline-block; margin-left:0px; vertical-align:top;">\n\ <input type="checkbox" name="like[11]" lay-skin="primary" title="fanatical" disabled=""><br>\n\ </div>\n\ </div>\n\ </div>\n\ </div>\n\ </form>\n\ </div>\n\ </fieldset>\n\ </div>\n\ \n\ <div class="layui-tab-item" style="background-color: rgba(0,0,0,0.2); color: #ebebeb;">\n\ <fieldset class="layui-elem-field">\n\ <legend>功能设置</legend>\n\ <div class="layui-field-box">\n\ \n\ <form class="layui-form" action="" lay-filter="example">\n\ <div class="layui-form-item" pane="">\n\ <label class="layui-form-label">Debug模式</label>\n\ <div class="layui-input-block">\n\ <!-- checked="" -->\n\ <input type="checkbox" name="close" lay-skin="switch" lay-filter="switchTest3" title="开关" lay-text="开启|关闭">\n\ </div>\n\ </div>\n\ </form>\n\ <div>弹出层</div>\n\ <div>滑块</div>\n\ <button type="button" class="layui-btn">导入导出重置当前设置</button>\n\ <div>弹出层</div>\n\ \n\ <div class="layui-upload-drag" id="uploadDemo">\n\ <i class="layui-icon"></i>\n\ <p>点击上传,或将文件拖拽到此处</p>\n\ <div class="layui-hide" id="uploadDemoView">\n\ <hr>\n\ <img src="" alt="上传成功后渲染" style="max-width: 100%">\n\ </div>\n\ </div>\n\ </div>\n\ </fieldset>\n\ \n\ <fieldset class="layui-elem-field">\n\ <legend>界面设置</legend>\n\ <div class="layui-field-box">\n\ \n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>语言配置</legend>\n\ <div id="selectLanguageDropdown" class="localizationTool"></div>\n\ <button type="button" class="layui-btn">自动检测(简体中文)</button>\n\ <button type="button" class="layui-btn">简体中文</button>\n\ <button type="button" class="layui-btn">繁体中文</button>\n\ <button type="button" class="layui-btn">English</button>\n\ </fieldset>\n\ \n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>主题切换</legend>\n\ <div>请选择一个主题,然后点击应用</div>\n\ <button type="button" class="layui-btn">应用主题</button>\n\ </fieldset>\n\ \n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>UI设置</legend>\n\ <div>预览:</div>\n\ <div>\n\ <span>主要字体颜色:</span>\n\ <span style="margin-left: 30px;">\n\ <input type="hidden" name="color" value="" id="test-all-input">\n\ <div id="test-all1"></div>\n\ </span>\n\ </div>\n\ \n\ <div>\n\ <span>主要背景颜色:</span>\n\ <span style="margin-left: 30px;">\n\ <input type="hidden" name="color" value="" id="test-all-input">\n\ <div id="test-all2"></div>\n\ </span>\n\ </div>\n\ \n\ <div>\n\ <span>留言成功字体颜色:</span>\n\ <span style="margin-left: 30px;">\n\ <input type="hidden" name="color" value="" id="test-all-input">\n\ <div id="test-all3"></div>\n\ </span>\n\ </div>\n\ \n\ <div>\n\ <span>留言失败字体颜色:</span>\n\ <span style="margin-left: 30px;">\n\ <input type="hidden" name="color" value="" id="test-all-input">\n\ <div id="test-all4"></div>\n\ </span>\n\ </div>\n\ \n\ <div>\n\ <span>留言发生错误字体颜色:</span>\n\ <span style="margin-left: 30px;">\n\ <input type="hidden" name="color" value="" id="test-all-input">\n\ <div id="test-all5"></div>\n\ </span>\n\ </div>\n\ \n\ <button type="button" class="layui-btn">保存为主题</button>\n\ </fieldset>\n\ \n\ </div>\n\ </fieldset>\n\ \n\ <fieldset class="layui-elem-field">\n\ <legend>关于SteamAssistant(Steam小助手)</legend>\n\ <div class="layui-field-box">\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>程序信息:</legend>\n\ <div>当前版本:v0.2.3.0</div>\n\ <div>主程序框架更新时间:2020年4月19日</div>\n\ <div>common模块:2020年4月19日</div>\n\ <div>databaseConf模块:2020年4月19日</div>\n\ <div>externalApis模块:2020年4月19日</div>\n\ <div>steamApis模块:2020年4月19日</div>\n\ <div>translateApis模块:2020年4月19日</div>\n\ <div>Utility模块:2020年4月19日</div>\n\ <div>UI模块:2020年4月19日</div>\n\ <div>Event模块:2020年4月19日</div>\n\ <div>CityList模块:2020年4月19日</div>\n\ <fieldset class="layui-elem-field layui-field-title">\n\ <legend>联系作者:</legend>\n\ <button type="button" class="layui-btn">反馈错误</button>\n\ <button type="button" class="layui-btn">提交建议</button>\n\ </div>\n\ </fieldset>\n\ \n\ <div id="sliderDemo" style="margin: 50px 20px;"></div>\n\ </div>\n\ \n\ </div>\n\ </div>\n\ '; var mainUI_template = '\ <script type="text/html" id="switchTpl">\n\ <!-- 这里的 checked 的状态只是演示 -->\n\ <input type="checkbox" name="front" value="{{d.id}}" lay-skin="switch" lay-text="是|否" lay-filter="frontDemo" {{ d.id == 10003 ? \'checked\' : \'\' }}>\n\ </script>\n\ \n\ <script type="text/html" id="checkboxTpl">\n\ <!-- 这里的 checked 的状态只是演示 -->\n\ <input type="checkbox" name="lock" value="{{d.id}}" title="锁定" lay-filter="lockDemo" {{ d.id == 10006 ? \'checked\' : \'\' }}>\n\ </script>\n\ '; var winBaseFrame = '\ <div></div>\n\ '; /** * JS_library.js */ function wordCount(data) { var intLength = 0; for (var i = 0; i < data.length; i++) { if ((data.charCodeAt(i) < 0) || (data.charCodeAt(i) > 255)) intLength = intLength + 3; else intLength = intLength + 1; } return intLength; } //var arrComment = []; /*id文本框的id, height文本框的高度, scrollTop存储收缩状态下的进度条, visible可见性*/ function inBoxShrinkage(id,type,mode = true){ /*参数: string 要伸缩的文本框id,boolean 是收缩还是伸展,boolean 需不需要重置滚动条(默认重置)*/ var iArr = -1; for(let i=0;i<arrComment.length;i++){ if(arrComment[i].id == id){ iArr = i; /*记录旧节点的下标*/ /*console.log('记录旧节点的下标','iArr',iArr);*/ break; } } if(iArr == -1){ arrComment.push( {id: id, height: 0, scrollTop: 0, visible: true} ); /*没有找到则是新的节点,就添加*/ iArr = arrComment.length - 1 ; /*设置新节点的下标*/ } var nHeight = arrComment[iArr].height; /*裁切字符串获取下标*/ if(nHeight==0){ /*第一次,没有指定的样式*/ nHeight = document.getElementById('comment_textarea').scrollHeight + 'px'; /*对于每个节点使用当前高度*/ } var commentText = document.getElementById(id); if (type == true){ commentText.removeEventListener('propertychange', change, false); commentText.removeEventListener('input', change, false); commentText.removeEventListener('focus', change, false); commentText.scrollTop = 0; /*代码位于event.js translationText翻译按钮事件*/ /*代码位于uiHandler.js 获取输入框和注册的scroll事件*/ /*代码位于ui.js inBoxShrinkage()判断是否需要重新进行定位*/ /*https://blog.csdn.net/zhengbo0/article/details/7629506*/ /*https://www.jb51.net/article/104047.htm*/ if((mode && arrComment[iArr].height > document.documentElement.clientHeight) || (mode && arrComment[iArr].visible == false)){ document.body.scrollTop = arrComment[iArr].scrollTop; document.documentElement.scrollTop = arrComment[iArr].scrollTop; console.log('重新进行定位'); } commentText.style.height = '28px'; } else if (type == false){ autoTextarea(commentText); if(mode){ arrComment[iArr].scrollTop = document.documentElement.scrollTop; /*设置 存储收缩状态下的进度条*/ } commentText.style.height = nHeight + 'px'; } else if (type == 'test'){ if(mode){ arrComment[iArr].scrollTop = document.documentElement.scrollTop; /*设置 存储收缩状态下的进度条*/ } commentText.style.height = nHeight + 'px'; } } var change; var autoTextarea = function autoTextarea(elem, extra, maxHeight) { extra = extra || 0; var isFirefox = !!document.getBoxObjectFor || 'mozInnerScreenX' in window, isOpera = !!window.opera && !!window.opera.toString().indexOf('Opera'), addEvent = function(type, callback) { elem.addEventListener ? elem.addEventListener(type, callback, false) : elem.attachEvent('on' + type, callback); }, getStyle = elem.currentStyle ? function(name) { var val = elem.currentStyle[name]; if (name === 'height' && val.search(/px/i) !== 1) { var rect = elem.getBoundingClientRect(); return rect.bottom - rect.top - parseFloat(getStyle('paddingTop')) - parseFloat(getStyle('paddingBottom')) + 'px'; }; return val; } : function(name) { return getComputedStyle(elem, null)[name]; }, minHeight = parseFloat(getStyle('height')); elem.style.resize = 'none'; change = function(e,id) { var scrollTop, height, padding = 0, style = elem.style; var obj = document.getElementById('strInBytes'); var commentText; if(id == undefined || id == null) commentText = document.getElementById(window.event.target.id); else commentText = document.getElementById(id); var numText = wordCount(commentText.value); obj.innerHTML = "当前字符字节数: <span id='strInBytes_Text'>" + numText + '</span>/999'; if (wordCount(commentText.value) >= 1000) { document.getElementById('strInBytes_Text').style.color = '#FF0000'; commentText.style.background = '#7C243E'; if(g_conf[0].isCommentRunStatus == false)/*如果正在留言则不清除(没有留言则清除)*/ jQuery('#log_head').html(''); jQuery('#log_head').html("<br><b style='color:#2CD8D6;'>字数超标啦! 请保持在1000字符以下. " + '当前字数:' + numText + '<b>'); g_conf[0].isWarnInfo = true; } else { document.getElementById('strInBytes_Text').style.color = '#32CD32'; commentText.style.background = '#1b2838'; if(g_conf[0].isCommentRunStatus == false && g_conf[0].isWarnInfo == true){ /*没有留言并且有警告信息才清除*/ jQuery('#log_head').html(''); g_conf[0].isWarnInfo = false; } } if (elem._length === elem.value.length) return; elem._length = elem.value.length; if (!isFirefox && !isOpera) { padding = parseInt(getStyle('paddingTop')) + parseInt(getStyle('paddingBottom')); }; scrollTop = document.body.scrollTop || document.documentElement.scrollTop; /*定位到最后*/ elem.style.height = minHeight + 'px'; if (elem.scrollHeight >= minHeight) { if (maxHeight && elem.scrollHeight > maxHeight) { height = maxHeight - padding; style.overflowY = 'auto'; } else { height = elem.scrollHeight - padding; style.overflowY = 'hidden'; }; style.height = height + extra + 'px'; var nHeight1 = height + extra; /*console.log('nHeight1',nHeight1,'newStr',newStr);*/ /*https://blog.csdn.net/weixin_34281477/article/details/93702604*/ /*https://www.cnblogs.com/cblogs/p/9293522.html*/ /*https://www.w3school.com.cn/tiy/t.asp?f=jseg_replace_1*/ var iIndex; for(let i=0;i<arrComment.length;i++) { if(id == undefined || id == null){ if(arrComment[i].id == window.event.target.id){ iIndex = i; break; } } else{ if(arrComment[i].id == id){ iIndex = i; break; } } } arrComment[iIndex].height = nHeight1;/*存储*/ scrollTop += parseInt(style.height) - elem.currHeight; if(!isNaN(scrollTop)){ document.body.scrollTop = scrollTop; document.documentElement.scrollTop = scrollTop; } elem.currHeight = parseInt(style.height); }; }; addEvent('propertychange', change); addEvent('input', change); /*addEvent('focus', change);*/ change(); }; function openThisAndCloseOtherAllinBoxShrinkage(id,type){ /*打开这个,关闭其他所有的inBoxShrinkage*/ inBoxShrinkage(id,type); /*展开*/ if(id != 'comment_textarea' && document.getElementById('comment_textarea') != null) inBoxShrinkage('comment_textarea',true,false); if(id != 'comment_textarea_en' && document.getElementById('comment_textarea_en') != null) inBoxShrinkage('comment_textarea_en',true,false); if(id != 'comment_textarea_jp' && document.getElementById('comment_textarea_jp') != null) inBoxShrinkage('comment_textarea_jp',true,false); if(id != 'comment_textarea_zhc' && document.getElementById('comment_textarea_zhc') != null) inBoxShrinkage('comment_textarea_zhc',true,false); if(id != 'comment_textarea_zh_sg' && document.getElementById('comment_textarea_zh_sg') != null) inBoxShrinkage('comment_textarea_zh_sg',true,false); if(id != 'comment_textarea_zh_hant' && document.getElementById('comment_textarea_zh_hant') != null) inBoxShrinkage('comment_textarea_zh_hant',true,false); if(id != 'comment_textarea_zh_hk' && document.getElementById('comment_textarea_zh_hk') != null) inBoxShrinkage('comment_textarea_zh_hk',true,false); if(id != 'comment_textarea_zh_mo' && document.getElementById('comment_textarea_zh_mo') != null) inBoxShrinkage('comment_textarea_zh_mo',true,false); if(id != 'comment_textarea_zh_tw' && document.getElementById('comment_textarea_zh_tw') != null) inBoxShrinkage('comment_textarea_zh_tw',true,false); } var inBoxonblurID = 0; function addEmojiEvent(emojiCode) { switch (inBoxonblurID){ case 0: let inObj = document.getElementById('comment_textarea'); inObj.value += ':' + emojiCode + ':'; /*添加表情*/ if(change != undefined) change(null, 'comment_textarea'); /*统计翻译后的文字长度*/ break; case 1: let inObj1 = document.getElementById('comment_textarea_en'); inObj1.value += ':' + emojiCode + ':'; /*添加表情*/ if(change != undefined) change(null, 'comment_textarea_en'); /*统计翻译后的文字长度*/ break; case 2: let inObj2 = document.getElementById('comment_textarea_jp'); inObj2.value += ':' + emojiCode + ':'; /*添加表情*/ if(change != undefined) change(null, 'comment_textarea_jp'); /*统计翻译后的文字长度*/ break; case 3: let inObj3 = document.getElementById('comment_textarea_zhc'); inObj3.value += ':' + emojiCode + ':'; /*添加表情*/ if(change != undefined) change(null, 'comment_textarea_zhc'); /*统计翻译后的文字长度*/ break; case 4: let inObj4 = document.getElementById('comment_textarea_zh_sg'); inObj4.value += ':' + emojiCode + ':'; /*添加表情*/ if(change != undefined) change(null, 'comment_textarea_zh_sg'); /*统计翻译后的文字长度*/ break; case 5: let inObj5 = document.getElementById('comment_textarea_zh_hant'); inObj5.value += ':' + emojiCode + ':'; /*添加表情*/ if(change != undefined) change(null, 'comment_textarea_zh_hant'); /*统计翻译后的文字长度*/ break; case 6: let inObj6 = document.getElementById('comment_textarea_zh_hk'); inObj6.value += ':' + emojiCode + ':'; /*添加表情*/ if(change != undefined) change(null, 'comment_textarea_zh_hk'); /*统计翻译后的文字长度*/ break; case 7: let inObj7 = document.getElementById('comment_textarea_zh_mo'); inObj7.value += ':' + emojiCode + ':'; /*添加表情*/ if(change != undefined) change(null, 'comment_textarea_zh_mo'); /*统计翻译后的文字长度*/ break; case 8: let inObj8 = document.getElementById('comment_textarea_zh_tw'); inObj8.value += ':' + emojiCode + ':'; /*添加表情*/ if(change != undefined) change(null, 'comment_textarea_zh_tw'); /*统计翻译后的文字长度*/ break; default: break; } } //---------------------------------------------------------------------------------------- function emojiFix() { /*修复表情*/ console.log("表情开始修复..."); let obj = document.getElementsByClassName("emoticon_popup es_emoticons")[0]; if (obj != undefined) { obj.style.position = "relative"; obj.style.zIndex = "999"; } let obj1 = document.getElementsByClassName("emoticon_popup_ctn")[0]; if (obj1 != undefined) { obj1.style.zIndex = "999"; } let emojiObjArrs = document.getElementsByClassName("emoticon_option"); if (emojiObjArrs.length > 0) { for (let i in emojiObjArrs) { emojiObjArrs[i].onclick = function() { addEmojiEvent(emojiObjArrs[i].getAttribute('data-emoticon')); } } console.log("表情修复完毕!"); } /*console.log("修复表情错误!");*/ } function dvWidthFix() { /*用于修复PC端留言提示内容溢出导致布局发生错误的问题*/ $("subpage_container").style.width = "calc(100% - 280px)"; } function deleteSelectText(){ /*删除选择的文本*/ window.getSelection().deleteFromDocument(); /*删除选择的文本*/ } var _ySelectsObj; function _ySelects($) { $.fn.ySelect = function(options) { var defaultOptions = { placeholder: '请选择', numDisplayed: 4, overflowText: '{n} selected', searchText: '搜索', showSearch: true } if (typeof options == 'string') { var settings = options; } else { var settings = $.extend(true, {}, defaultOptions, options); } function ySelect(select, settings) { this.$select = $(select); this.settings = settings; this.create(); } ySelect.prototype = { create: function() { var multiple = this.$select.is('[multiple]') ? ' multiple' : ''; this.$select.wrap('<div class="fs-wrap' + multiple + '"></div>'); this.$select.before('<div class="fs-label-wrap"><div class="fs-label">' + this.settings.placeholder + '</div><span class="fs-arrow"></span></div>'); this.$select.before('<div class="fs-dropdown hidden"><div class="fs-options"></div></div>'); this.$select.addClass('hidden'); this.$wrap = this.$select.closest('.fs-wrap'); this.reload(); }, reload: function() { if (this.settings.showSearch) { var search = '<div class="fs-search"><input type="search" placeholder="' + this.settings.searchText + '" /><span class="fs-selectAll"><i class="fa fa-check-square-o"></i></span></div>'; this.$wrap.find('.fs-dropdown').prepend(search); } var choices = this.buildOptions(this.$select); this.$wrap.find('.fs-options').html(choices); this.reloadDropdownLabel(); }, destroy: function() { this.$wrap.find('.fs-label-wrap').remove(); this.$wrap.find('.fs-dropdown').remove(); this.$select.unwrap().removeClass('hidden'); }, buildOptions: function($element) { var $this = this; var choices = ''; $element.children().each(function(i, el) { var $el = $(el); if ('optgroup' == $el.prop('nodeName').toLowerCase()) { choices += '<div class="fs-optgroup">'; choices += '<div class="fs-optgroup-label">' + $el.prop('label') + '</div>'; choices += $this.buildOptions($el); choices += '</div>'; } else { var selected = $el.is('[selected]') ? ' selected' : ''; choices += '<div class="fs-option' + selected + '" data-value="' + $el.prop('value') + '"><span class="fs-checkbox"><i></i></span><div class="fs-option-label">' + $el.html() + '</div></div>'; } }); return choices; }, reloadDropdownLabel: function() { var settings = this.settings; var labelText = []; this.$wrap.find('.fs-option.selected').each(function(i, el) { labelText.push($(el).find('.fs-option-label').text()); }); if (labelText.length < 1) { labelText = settings.placeholder; } else if (labelText.length > settings.numDisplayed) { labelText = settings.overflowText.replace('{n}', labelText.length); } else { labelText = labelText.join(', '); } this.$wrap.find('.fs-label').html(labelText); this.$select.change(); }, setwrap: function() { return "123"; }, } return this.each(function() { var data = $(this).data('ySelect'); if (!data) { data = new ySelect(this, settings); _ySelectsObj = data; $(this).data('ySelect', data); } if (typeof settings == 'string') { data[settings](); } }); } window.ySelect = { 'active': null, 'idx': -1 }; function setIndexes($wrap) { $wrap.find('.fs-option:not(.hidden)').each(function(i, el) { $(el).attr('data-index', i); $wrap.find('.fs-option').removeClass('hl'); }); $wrap.find('.fs-search input').focus(); window.ySelect.idx = -1; } function setScroll($wrap) { var $container = $wrap.find('.fs-options'); var $selected = $wrap.find('.fs-option.hl'); var itemMin = $selected.offset().top + $container.scrollTop(); var itemMax = itemMin + $selected.outerHeight(); var containerMin = $container.offset().top + $container.scrollTop(); var containerMax = containerMin + $container.outerHeight(); if (itemMax > containerMax) { var to = $container.scrollTop() + itemMax - containerMax; $container.scrollTop(to); } else if (itemMin < containerMin) { var to = $container.scrollTop() - containerMin - itemMin; $container.scrollTop(to); } } $(document).on('click', '.fs-selectAll', function() { $(this).parent().next().find('.fs-option.selected').click(); $(this).parent().next().find('.fs-option').click(); $(this).addClass('selected'); }); $(document).on('click', '.fs-selectAll.selected', function() { $(this).parent().next().find('.fs-option.selected').click(); $(this).removeClass('selected'); }); $(document).on('click', '.fs-option', function() { var $wrap = $(this).closest('.fs-wrap'); if ($wrap.hasClass('multiple')) { var selected = []; $(this).toggleClass('selected'); $wrap.find('.fs-option.selected').each(function(i, el) { selected.push($(el).attr('data-value')); }); } else { var selected = $(this).attr('data-value'); $wrap.find('.fs-option').removeClass('selected'); $(this).addClass('selected'); $wrap.find('.fs-dropdown').hide(); } $wrap.find('select').val(selected); $wrap.find('select').ySelect('reloadDropdownLabel'); $wrap.find('select').ySelect('setwrap'); }); $(document).on('keyup', '.fs-search input', function(e) { if (40 == e.which) { $(this).blur(); return; } var $wrap = $(this).closest('.fs-wrap'); var keywords = $(this).val(); $wrap.find('.fs-option, .fs-optgroup-label').removeClass('hidden'); if ('' != keywords) { $wrap.find('.fs-option').each(function() { var regex = new RegExp(keywords, 'gi'); if (null === $(this).find('.fs-option-label').text().match(regex)) { $(this).addClass('hidden'); } }); $wrap.find('.fs-optgroup-label').each(function() { var num_visible = $(this).closest('.fs-optgroup').find('.fs-option:not(.hidden)').length; if (num_visible < 1) { $(this).addClass('hidden'); } }); } setIndexes($wrap); }); $(document).on('click', function(e) { var $el = $(e.target); var $wrap = $el.closest('.fs-wrap'); if (0 < $wrap.length) { if ($el.hasClass('fs-label') || $el.hasClass('fs-arrow')) { window.ySelect.active = $wrap; var is_hidden = $wrap.find('.fs-dropdown').hasClass('hidden'); $('.fs-dropdown').addClass('hidden'); if (is_hidden) { $wrap.find('.fs-dropdown').removeClass('hidden'); } else { $wrap.find('.fs-dropdown').addClass('hidden'); } setIndexes($wrap); } } else { $('.fs-dropdown').addClass('hidden'); window.ySelect.active = null; } }); $(document).on('keydown', function(e) { var $wrap = window.ySelect.active; if (null === $wrap) { return; } else if (38 == e.which) { e.preventDefault(); $wrap.find('.fs-option').removeClass('hl'); if (window.ySelect.idx > 0) { window.ySelect.idx--; $wrap.find('.fs-option[data-index=' + window.ySelect.idx + ']').addClass('hl'); setScroll($wrap); } else { window.ySelect.idx = -1; $wrap.find('.fs-search input').focus(); } } else if (40 == e.which) { e.preventDefault(); var last_index = $wrap.find('.fs-option:last').attr('data-index'); if (window.ySelect.idx < parseInt(last_index)) { window.ySelect.idx++; $wrap.find('.fs-option').removeClass('hl'); $wrap.find('.fs-option[data-index=' + window.ySelect.idx + ']').addClass('hl'); setScroll($wrap); } } else if (32 == e.which || 13 == e.which) { $wrap.find('.fs-option.hl').click(); } else if (27 == e.which) { $('.fs-dropdown').addClass('hidden'); window.ySelect.active = null; } }); $.fn.ySelectedValues = function(splitString) { var result = ""; var $selects = this.find("option:selected"); for (var i = 0; i < $selects.length; i++) { result += $selects[i].value + ((i == $selects.length - 1) ? "" : splitString); } return result; } $.fn.ySelectedTexts = function(splitString) { var result = ""; var $selects = this.find("option:selected"); for (var i = 0; i < $selects.length; i++) { result += $selects[i].text + ((i == $selects.length - 1) ? "" : splitString); } return result; } } const _RESMODE = { res_Tampermonkey: "Tampermonkey-Res", res_CDN: "CDN-CommonRequest", res_LocalVariables: "JS-LocalVariables" }; const _RESTYPE = { res_css: "css", res_js: "js", res_json: "json" }; /** * @param {String} strResID 资源id */ function getResConfByID(strResID){ if(_resConf){ for (let i = 0; i < _resConf.length; i++) { if(_resConf[i].resID == strResID) return _resConf[i].resInfo; } return new Error("[sophie] not find strResID."); } else{ throw new Error("[sophie] _resConf is undefined."); } } function patchJS_layui(resData){ //对 o.prototype.addcss 打补丁,使其直接return this, 而不是去加载css, css通过脚本欲加载的资源手动添加 var findStr = 'layui.link(n.dir+"css/"+e,t,o)'; var index = resData.indexOf(findStr); //查找代补丁代码的位置 var fixJS = resData.slice(0,index); //提取 代补丁代码前部分 fixJS += 'this'; //添加 补丁代码 fixJS += resData.slice(index+findStr.length); //提取 代补丁代码后部分 return fixJS; } const _resConf = [ { resID: "BaseResources", //资源唯一id resInfo: [ //资源相关信息 { resName: "css_layui", //资源名称 resDescription: "layui库所需的css", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resMode: _RESMODE.res_Tampermonkey, resType: _RESTYPE.res_css, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: ["css_layui"], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resMode: _RESTYPE.res_CDN, resType: _RESTYPE.res_css, isFight: false, sourceInfo: [ "https://www.layuicdn.com/layui-v2.5.6/css/layui.css", "https://cdnjs.cloudflare.com/ajax/libs/layui/2.5.6/css/layui.css", "https://cdn.90so.net/layui/2.5.6/css/layui.css", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "css_laydate", //资源名称 resDescription: "layui库(laydate组件)所需的css", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resMode: _RESMODE.res_Tampermonkey, resType: _RESTYPE.res_css, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: ["css_laydate"], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resMode: _RESTYPE.res_CDN, resType: _RESTYPE.res_css, isFight: false, sourceInfo: [ "https://www.layuicdn.com/layui-v2.5.6/css/modules/laydate/default/laydate.css?v=5.0.9", "https://cdnjs.cloudflare.com/ajax/libs/layui/2.5.6/css/modules/laydate/default/laydate.css?v=5.0.9", "https://cdn.90so.net/layui/2.5.6/css/modules/laydate/default/laydate.css?v=5.0.9", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "css_layer", //资源名称 resDescription: "layui库(layer组件)所需的css", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resMode: _RESMODE.res_Tampermonkey, resType: _RESTYPE.res_css, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: ["css_layer"], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resMode: _RESTYPE.res_CDN, resType: _RESTYPE.res_css, isFight: false, sourceInfo: [ "https://www.layuicdn.com/layui-v2.5.6/css/modules/layer/default/layer.css?v=3.1.1", "https://cdnjs.cloudflare.com/ajax/libs/layui/2.5.6/css/modules/layer/default/layer.css?v=3.1.1", "https://cdn.90so.net/layui/2.5.6/css/modules/layer/default/layer.css?v=3.1.1", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "css_layui_Modules", //资源名称 resDescription: "layui库(组件)所需的css", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resMode: _RESMODE.res_Tampermonkey, resType: _RESTYPE.res_css, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: ["css_layui_Modules"], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resMode: _RESTYPE.res_CDN, resType: _RESTYPE.res_css, isFight: false, sourceInfo: [ "https://www.layuicdn.com/layui-v2.5.6/css/modules/code.css", "https://cdnjs.cloudflare.com/ajax/libs/layui/2.5.6/css/modules/code.css", "https://cdn.90so.net/layui/2.5.6/css/modules/code.css", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "css_fontAwesome", //资源名称 resDescription: "fontAwesome库所需的css", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resMode: _RESMODE.res_Tampermonkey, resType: _RESTYPE.res_css, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: ["css_fontAwesome"], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resMode: _RESTYPE.res_CDN, resType: _RESTYPE.res_css, isFight: false, sourceInfo: [ "https://cdn.bootcss.com/font-awesome/4.7.0/css/font-awesome.min.css", "https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css", "https://stackpath.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "JS_highstock", //资源名称 resDescription: "", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resMode: _RESMODE.res_Tampermonkey, resType: _RESTYPE.res_js, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: ["JS_highstock"], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resMode: _RESTYPE.res_CDN, resType: _RESTYPE.res_js, isFight: false, sourceInfo: [ "https://code.highcharts.com.cn/highstock/highstock.js", "https://cdnjs.cloudflare.com/ajax/libs/highcharts/8.1.0/highstock.min.js", "https://cdn.bootcdn.net/ajax/libs/highcharts/8.1.0/highstock.js", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "JS_highstock_exporting", //资源名称 resDescription: "", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resMode: _RESMODE.res_Tampermonkey, resType: _RESTYPE.res_js, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: ["JS_highstock_exporting"], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resMode: _RESTYPE.res_CDN, resType: _RESTYPE.res_js, isFight: false, sourceInfo: [ "https://code.highcharts.com.cn/highcharts/modules/exporting.js", "https://cdnjs.cloudflare.com/ajax/libs/highcharts/8.1.0/modules/exporting.min.js", "https://cdn.bootcdn.net/ajax/libs/highcharts/8.1.0/modules/exporting.js", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "JS_highstock_oldie", //资源名称 resDescription: "", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resMode: _RESMODE.res_Tampermonkey, resType: _RESTYPE.res_js, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: ["JS_highstock_oldie"], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resMode: _RESTYPE.res_CDN, resType: _RESTYPE.res_js, isFight: false, sourceInfo: [ "https://code.highcharts.com.cn/highcharts/modules/oldie.js", "https://cdnjs.cloudflare.com/ajax/libs/highcharts/8.1.0/modules/oldie.src.min.js", "https://cdn.bootcdn.net/ajax/libs/highcharts/8.1.0/modules/oldie.js", ], onSucceed: null ,//如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "JS_highstock_networkgraph", //资源名称 resDescription: "", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resMode: _RESMODE.res_Tampermonkey, resType: _RESTYPE.res_js, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: ["JS_highstock_networkgraph"], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resMode: _RESTYPE.res_CDN, resType: _RESTYPE.res_js, isFight: false, sourceInfo: [ "https://code.highcharts.com.cn/highcharts/modules/networkgraph.js", "https://cdnjs.cloudflare.com/ajax/libs/highcharts/8.1.0/modules/networkgraph.min.js", "https://cdn.bootcdn.net/ajax/libs/highcharts/8.1.0/modules/networkgraph.js", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "JS_highstock_zh_CN", //资源名称 resDescription: "", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resMode: _RESMODE.res_Tampermonkey, resType: _RESTYPE.res_js, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: ["JS_highstock_zh_CN"], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resMode: _RESTYPE.res_CDN, resType: _RESTYPE.res_js, isFight: false, sourceInfo: [ "https://code.highcharts.com.cn/highcharts-plugins/highcharts-zh_CN.js", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "JS_layui", //资源名称 resDescription: "", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resMode: _RESMODE.res_Tampermonkey, resType: _RESTYPE.res_js, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: ["JS_layui"], onSucceed: patchJS_layui //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resMode: _RESTYPE.res_CDN, resType: _RESTYPE.res_js, isFight: false, sourceInfo: [ "https://www.layuicdn.com/layui-v2.5.6/layui.all.js", "https://cdnjs.cloudflare.com/ajax/libs/layui/2.5.6/layui.all.min.js", "https://cdn.90so.net/layui/2.5.6/layui.all.js", ], onSucceed: patchJS_layui //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "JS_localforage", //资源名称 resDescription: "", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resMode: _RESMODE.res_Tampermonkey, resType: _RESTYPE.res_js, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: ["JS_localforage"], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resMode: _RESTYPE.res_CDN, resType: _RESTYPE.res_js, isFight: false, sourceInfo: [ "https://cdnjs.cloudflare.com/ajax/libs/localforage/1.7.3/localforage.min.js", "https://cdn.90so.net/localforage/1.7.3/localforage.min.js", "https://cdn.bootcdn.net/ajax/libs/localforage/1.7.3/localforage.min.js", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "css_jquery_localizationTool", //资源名称 resDescription: "", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resMode: _RESMODE.res_LocalVariables, resType: _RESTYPE.res_css, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: ["jquery_localizationTool_css"], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "js_jquery_localizationTool", //资源名称 resDescription: "", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resMode: _RESMODE.res_Tampermonkey, resType: _RESTYPE.res_js, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: ["Jquery_localizationtool"], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resMode: _RESTYPE.res_CDN, resType: _RESTYPE.res_js, isFight: false, sourceInfo: [ "https://greasyfork.org/scripts/403927-jquery-localizationtool-js/code/jquerylocalizationTooljs.js?version=808323", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] } ] }, { resID: "ExpandResources", //资源唯一id resInfo: [ //资源相关信息 { resName: "", //资源名称 resDescription: "", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resType: _RESTYPE.res_Tampermonkey, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: [ "", "", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resType: _RESTYPE.res_CDN, isFight: false, sourceInfo: [ "", "", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "", //资源名称 resDescription: "", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resType: _RESTYPE.res_Tampermonkey, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: [ "", "", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resType: _RESTYPE.res_CDN, isFight: false, sourceInfo: [ "", "", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] }, { resName: "", //资源名称 resDescription: "", //资源描述 res: [ //资源信息: 为了保证最大可用性, 资源可以从多种途径加载, 越前的资源加载优先级越高 { resType: _RESTYPE.res_Tampermonkey, isFight: false, // 同一个资源下,可以手动设置是否需要启动争抢模式,谁先加载完就使用谁的 sourceInfo: [ "", "", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) }, { resType: _RESTYPE.res_CDN, isFight: false, sourceInfo: [ "", "", ], onSucceed: null //如果获取资源成功后的回调函数(立刻触发,可用于取消加载资源,资源检查等) } ] } ] } ]; function injectJS(){ var funcCode = ""; funcCode += wordCount.toString() + "\n\n"; funcCode += "var arrComment = []; /*id文本框的id, height文本框的高度, scrollTop存储收缩状态下的进度条, visible可见性*/" + "\n"; funcCode += inBoxShrinkage.toString() + "\n\n"; funcCode += "var change;" + "\n"; funcCode += autoTextarea.toString() + "\n\n"; funcCode += openThisAndCloseOtherAllinBoxShrinkage.toString() + "\n\n"; funcCode += "var inBoxonblurID = 0;" + "\n"; funcCode += addEmojiEvent.toString() + "\n\n"; addNewScript('styles_Script',funcCode); var funcCode = ""; funcCode += emojiFix.toString() + "\n\n"; funcCode += dvWidthFix.toString() + "\n\n"; funcCode += deleteSelectText.toString() + "\n\n"; funcCode += _ySelects.toString() + "\n\n"; addNewScript('Utility_Script',funcCode); } var languagesList_ExpandUI_QuickNavigationBar_html = { 'defaultLanguage' : 'auto_detected', /* (optional) although must be defined if you don't want en_GB */ 'showFlag': false, /* (optional) show/hide the flag 显示/隐藏旗帜 */ 'showCountry': false, /* (optional) show/hide the country name 显示/隐藏国家名称 */ 'showLanguage': true, /* (optional) show/hide the country language 显示/隐藏国家语言 */ 'labelTemplate': '{{language}}', 'languages' : { /* (optional) define **ADDITIONAL** custom languages 定义**额外的**自定义语言 */ 'auto_detected' : { 'country': 'Auto Detected', 'language' : 'Auto Detected', 'countryTranslated': 'Auto Detected', 'languageTranslated': 'Auto Detected', 'flag' : { 'url' : 'https://upload.wikimedia.org/wikipedia/commons/2/22/Flag_of_Hokkaido_Prefecture.svg', /* url of flag image 标志图像url */ 'class' : 'auto-flag' /* (optional) class to assign to the flag (e.g., for css styling) 类来分配给标志(例如,用于css样式) */ } } }, /* * Translate your strings below 翻译下面的字符串 */ 'strings' : { 'class:localTool_1_1' : { /*要翻译的字符串*/ 'auto_detected' : '快捷导航栏', /*自动检测*/ 'zh_CN' : '快捷导航栏', /*简体*/ 'zh_TW' : '快捷導航欄', /*繁体*/ 'en_GB' : 'Quick Navigation Bar', /*英语*/ 'jp_JP' : 'クイックナビゲーションバー' /*日语*/ }, 'class:localTool_1_2' : { /*要翻译的字符串*/ 'auto_detected' : '好友分组', /*自动检测*/ 'zh_CN' : '好友分组', /*简体*/ 'zh_TW' : '好友分組', /*繁体*/ 'en_GB' : 'Friends group', /*英语*/ 'jp_JP' : '友達グループ' /*日语*/ }, 'class:localTool_1_3' : { /*要翻译的字符串*/ 'auto_detected' : '选项一', /*自动检测*/ 'zh_CN' : '选项一', /*简体*/ 'zh_TW' : '選項一', /*繁体*/ 'en_GB' : 'Option 1', /*英语*/ 'jp_JP' : 'オプション1' /*日语*/ }, 'class:localTool_1_4' : { /*要翻译的字符串*/ 'auto_detected' : '选项二', /*自动检测*/ 'zh_CN' : '选项二', /*简体*/ 'zh_TW' : '選項二', /*繁体*/ 'en_GB' : 'Option 2', /*英语*/ 'jp_JP' : 'オプション2' /*日语*/ }, 'class:localTool_1_5' : { /*要翻译的字符串*/ 'auto_detected' : '选项三', /*自动检测*/ 'zh_CN' : '选项三', /*简体*/ 'zh_TW' : '選項三', /*繁体*/ 'en_GB' : 'Option 3', /*英语*/ 'jp_JP' : 'オプション3' /*日语*/ }, 'class:localTool_1_6' : { /*要翻译的字符串*/ 'auto_detected' : '跳转项', /*自动检测*/ 'zh_CN' : '跳转项', /*简体*/ 'zh_TW' : '跳轉項', /*繁体*/ 'en_GB' : 'Jump items', /*英语*/ 'jp_JP' : 'ジャンプのアイテム' /*日语*/ }, 'class:localTool_1_7' : { /*要翻译的字符串*/ 'auto_detected' : '功能模块', /*自动检测*/ 'zh_CN' : '功能模块', /*简体*/ 'zh_TW' : '功能模塊', /*繁体*/ 'en_GB' : 'functional module', /*英语*/ 'jp_JP' : '機能モジュール' /*日语*/ }, 'class:localTool_1_8' : { /*要翻译的字符串*/ 'auto_detected' : '选项一', /*自动检测*/ 'zh_CN' : '选项一', /*简体*/ 'zh_TW' : '選項一', /*繁体*/ 'en_GB' : 'Option 1', /*英语*/ 'jp_JP' : 'オプション1' /*日语*/ }, 'class:localTool_1_9' : { /*要翻译的字符串*/ 'auto_detected' : '选项二', /*自动检测*/ 'zh_CN' : '选项二', /*简体*/ 'zh_TW' : '選項二', /*繁体*/ 'en_GB' : 'Option 2', /*英语*/ 'jp_JP' : 'オプション2' /*日语*/ }, 'class:localTool_1_10' : { /*要翻译的字符串*/ 'auto_detected' : '选项三', /*自动检测*/ 'zh_CN' : '选项三', /*简体*/ 'zh_TW' : '選項三', /*繁体*/ 'en_GB' : 'Option 3', /*英语*/ 'jp_JP' : 'オプション3' /*日语*/ }, 'class:localTool_1_11' : { /*要翻译的字符串*/ 'auto_detected' : '跳转项', /*自动检测*/ 'zh_CN' : '跳转项', /*简体*/ 'zh_TW' : '跳轉項', /*繁体*/ 'en_GB' : 'Jump items', /*英语*/ 'jp_JP' : 'ジャンプのアイテム' /*日语*/ }, 'class:localTool_1_12' : { /*要翻译的字符串*/ 'auto_detected' : '其他', /*自动检测*/ 'zh_CN' : '其他', /*简体*/ 'zh_TW' : '其他', /*繁体*/ 'en_GB' : 'other', /*英语*/ 'jp_JP' : '他の' /*日语*/ }, 'class:localTool_1_13' : { /*要翻译的字符串*/ 'auto_detected' : '返回顶部', /*自动检测*/ 'zh_CN' : '返回顶部', /*简体*/ 'zh_TW' : '返回頂部', /*繁体*/ 'en_GB' : 'Back to top', /*英语*/ 'jp_JP' : 'トップに戻る' /*日语*/ }, 'class:localTool_1_14' : { /*要翻译的字符串*/ 'auto_detected' : '返回底部', /*自动检测*/ 'zh_CN' : '返回底部', /*简体*/ 'zh_TW' : '返回底部', /*繁体*/ 'en_GB' : 'Returns to the bottom', /*英语*/ 'jp_JP' : '下へ戻ります' /*日语*/ }, 'class:localTool_1_15' : { /*要翻译的字符串*/ 'auto_detected' : '选项三', /*自动检测*/ 'zh_CN' : '选项三', /*简体*/ 'zh_TW' : '選項三', /*繁体*/ 'en_GB' : 'Option 3', /*英语*/ 'jp_JP' : 'オプション3' /*日语*/ }, 'class:localTool_1_16' : { /*要翻译的字符串*/ 'auto_detected' : '跳转项', /*自动检测*/ 'zh_CN' : '跳转项', /*简体*/ 'zh_TW' : '跳轉項', /*繁体*/ 'en_GB' : 'Jump items', /*英语*/ 'jp_JP' : 'ジャンプのアイテム' /*日语*/ }, 'class:localTool_1_17' : { /*要翻译的字符串*/ 'auto_detected' : '解决方案', /*自动检测*/ 'zh_CN' : '解决方案', /*简体*/ 'zh_TW' : '解決方案', /*繁体*/ 'en_GB' : 'solution', /*英语*/ 'jp_JP' : '解決' /*日语*/ }, 'class:localTool_1_18' : { /*要翻译的字符串*/ 'auto_detected' : '移动模块', /*自动检测*/ 'zh_CN' : '移动模块', /*简体*/ 'zh_TW' : '移動模塊', /*繁体*/ 'en_GB' : 'Mobile Module', /*英语*/ 'jp_JP' : 'モバイルモジュール' /*日语*/ }, 'class:localTool_1_19' : { /*要翻译的字符串*/ 'auto_detected' : '后台模版', /*自动检测*/ 'zh_CN' : '后台模版', /*简体*/ 'zh_TW' : '後台模板', /*繁体*/ 'en_GB' : 'Background template', /*英语*/ 'jp_JP' : '背景テンプレート' /*日语*/ }, 'class:localTool_1_20' : { /*要翻译的字符串*/ 'auto_detected' : '电商平台', /*自动检测*/ 'zh_CN' : '电商平台', /*简体*/ 'zh_TW' : '電商平台', /*繁体*/ 'en_GB' : 'Electronic business platform', /*英语*/ 'jp_JP' : '電子ビジネスプラットフォーム' /*日语*/ }, 'class:localTool_1_21' : { /*要翻译的字符串*/ 'auto_detected' : '云市场', /*自动检测*/ 'zh_CN' : '云市场', /*简体*/ 'zh_TW' : '雲市場', /*繁体*/ 'en_GB' : 'Cloud Market', /*英语*/ 'jp_JP' : 'クラウド市場' /*日语*/ }, } }; var languagesList_groupUI_html = { 'defaultLanguage' : 'auto_detected', /* (optional) although must be defined if you don't want en_GB */ 'showFlag': false, /* (optional) show/hide the flag 显示/隐藏旗帜 */ 'showCountry': false, /* (optional) show/hide the country name 显示/隐藏国家名称 */ 'showLanguage': true, /* (optional) show/hide the country language 显示/隐藏国家语言 */ 'labelTemplate': '{{language}}', 'languages' : { /* (optional) define **ADDITIONAL** custom languages 定义**额外的**自定义语言 */ 'auto_detected' : { 'country': 'Auto Detected', 'language' : 'Auto Detected', 'countryTranslated': 'Auto Detected', 'languageTranslated': 'Auto Detected', 'flag' : { 'url' : 'https://upload.wikimedia.org/wikipedia/commons/2/22/Flag_of_Hokkaido_Prefecture.svg', /* url of flag image 标志图像url */ 'class' : 'auto-flag' /* (optional) class to assign to the flag (e.g., for css styling) 类来分配给标志(例如,用于css样式) */ } } }, /* * Translate your strings below 翻译下面的字符串 */ 'strings' : { 'class:localTool_2_1' : { /*要翻译的字符串*/ 'auto_detected' : '留言', /*自动检测*/ 'zh_CN' : '留言', /*简体*/ 'zh_TW' : '留言1', /*繁体*/ 'en_GB' : '留言2', /*英语*/ 'jp_JP' : '留言3' /*日语*/ }, 'class:localTool_2_2' : { /*要翻译的字符串*/ 'auto_detected' : '留言设置', /*自动检测*/ 'zh_CN' : '留言设置', /*简体*/ 'zh_TW' : '留言设置1', /*繁体*/ 'en_GB' : '留言设置2', /*英语*/ 'jp_JP' : '留言设置3' /*日语*/ }, 'class:localTool_2_3' : { /*要翻译的字符串*/ 'auto_detected' : '数据分析', /*自动检测*/ 'zh_CN' : '数据分析', /*简体*/ 'zh_TW' : '数据分析1', /*繁体*/ 'en_GB' : '数据分析2', /*英语*/ 'jp_JP' : '数据分析3' /*日语*/ }, 'class:localTool_2_4' : { /*要翻译的字符串*/ 'auto_detected' : '点赞助手', /*自动检测*/ 'zh_CN' : '点赞助手', /*简体*/ 'zh_TW' : '点赞助手1', /*繁体*/ 'en_GB' : '点赞助手2', /*英语*/ 'jp_JP' : '点赞助手3' /*日语*/ }, 'class:localTool_2_5' : { /*要翻译的字符串*/ 'auto_detected' : '拓展功能(测试)', /*自动检测*/ 'zh_CN' : '拓展功能(测试)', /*简体*/ 'zh_TW' : '拓展功能(测试)1', /*繁体*/ 'en_GB' : '拓展功能(测试)2', /*英语*/ 'jp_JP' : '拓展功能(测试)3' /*日语*/ }, 'class:localTool_2_6' : { /*要翻译的字符串*/ 'auto_detected' : '设置', /*自动检测*/ 'zh_CN' : '设置', /*简体*/ 'zh_TW' : '设置1', /*繁体*/ 'en_GB' : '设置2', /*英语*/ 'jp_JP' : '设置3' /*日语*/ }, 'class:localTool_2_7' : { /*要翻译的字符串*/ 'auto_detected' : '当前字符字节数:', /*自动检测*/ 'zh_CN' : '当前字符字节数:', /*简体*/ 'zh_TW' : '当前字符字节数:1', /*繁体*/ 'en_GB' : '当前字符字节数:2', /*英语*/ 'jp_JP' : '当前字符字节数:3' /*日语*/ }, 'class:localTool_2_8' : { /*要翻译的字符串*/ 'auto_detected' : '0', /*自动检测*/ 'zh_CN' : '0', /*简体*/ 'zh_TW' : '01', /*繁体*/ 'en_GB' : '02', /*英语*/ 'jp_JP' : '03' /*日语*/ }, 'class:localTool_2_9' : { /*要翻译的字符串*/ 'auto_detected' : '/999', /*自动检测*/ 'zh_CN' : '/999', /*简体*/ 'zh_TW' : '/9991', /*繁体*/ 'en_GB' : '/9992', /*英语*/ 'jp_JP' : '/9993' /*日语*/ }, 'class:localTool_2_10' : { /*要翻译的字符串*/ 'auto_detected' : '文本格式(直接添加或选择文字添加)', /*自动检测*/ 'zh_CN' : '文本格式(直接添加或选择文字添加)', /*简体*/ 'zh_TW' : '文本格式(直接添加或选择文字添加)1', /*繁体*/ 'en_GB' : '文本格式(直接添加或选择文字添加)2', /*英语*/ 'jp_JP' : '文本格式(直接添加或选择文字添加)3' /*日语*/ }, 'class:localTool_2_11' : { /*要翻译的字符串*/ 'auto_detected' : '直接选择或搜索选择', /*自动检测*/ 'zh_CN' : '直接选择或搜索选择', /*简体*/ 'zh_TW' : '直接选择或搜索选择1', /*繁体*/ 'en_GB' : '直接选择或搜索选择2', /*英语*/ 'jp_JP' : '直接选择或搜索选择3' /*日语*/ }, 'class:localTool_2_12' : { /*要翻译的字符串*/ 'auto_detected' : '[h1]标题文字[/h1]', /*自动检测*/ 'zh_CN' : '[h1]标题文字[/h1]', /*简体*/ 'zh_TW' : '[h1]标题文字[/h1]1', /*繁体*/ 'en_GB' : '[h1]标题文字[/h1]2', /*英语*/ 'jp_JP' : '[h1]标题文字[/h1]3' /*日语*/ }, 'class:localTool_2_13' : { /*要翻译的字符串*/ 'auto_detected' : '[b]粗体文本[/b]', /*自动检测*/ 'zh_CN' : '[b]粗体文本[/b]', /*简体*/ 'zh_TW' : '[b]粗体文本[/b]1', /*繁体*/ 'en_GB' : '[b]粗体文本[/b]2', /*英语*/ 'jp_JP' : '[b]粗体文本[/b]3' /*日语*/ }, 'class:localTool_2_14' : { /*要翻译的字符串*/ 'auto_detected' : '[u]下划线文本[/u]', /*自动检测*/ 'zh_CN' : '[u]下划线文本[/u]', /*简体*/ 'zh_TW' : '[u]下划线文本[/u]1', /*繁体*/ 'en_GB' : '[u]下划线文本[/u]2', /*英语*/ 'jp_JP' : '[u]下划线文本[/u]3' /*日语*/ }, 'class:localTool_2_15' : { /*要翻译的字符串*/ 'auto_detected' : '[i]斜体文本[/i]', /*自动检测*/ 'zh_CN' : '[i]斜体文本[/i]', /*简体*/ 'zh_TW' : '[i]斜体文本[/i]1', /*繁体*/ 'en_GB' : '[i]斜体文本[/i]2', /*英语*/ 'jp_JP' : '[i]斜体文本[/i]3' /*日语*/ }, 'class:localTool_2_16' : { /*要翻译的字符串*/ 'auto_detected' : '[strike]删除文本[/strike]', /*自动检测*/ 'zh_CN' : '[strike]删除文本[/strike]', /*简体*/ 'zh_TW' : '[strike]删除文本[/strike]1', /*繁体*/ 'en_GB' : '[strike]删除文本[/strike]2', /*英语*/ 'jp_JP' : '[strike]删除文本[/strike]3' /*日语*/ }, 'class:localTool_2_17' : { /*要翻译的字符串*/ 'auto_detected' : '[spoiler]隐藏文本[/spoiler]', /*自动检测*/ 'zh_CN' : '[spoiler]隐藏文本[/spoiler]', /*简体*/ 'zh_TW' : '[spoiler]隐藏文本[/spoiler]1', /*繁体*/ 'en_GB' : '[spoiler]隐藏文本[/spoiler]2', /*英语*/ 'jp_JP' : '[spoiler]隐藏文本[/spoiler]3' /*日语*/ }, 'class:localTool_2_18' : { /*要翻译的字符串*/ 'auto_detected' : '[noparse]不解析[b]标签[/b][/noparse]', /*自动检测*/ 'zh_CN' : '[noparse]不解析[b]标签[/b][/noparse]', /*简体*/ 'zh_TW' : '[noparse]不解析[b]标签[/b][/noparse]1', /*繁体*/ 'en_GB' : '[noparse]不解析[b]标签[/b][/noparse]2', /*英语*/ 'jp_JP' : '[noparse]不解析[b]标签[/b][/noparse]3' /*日语*/ }, 'class:localTool_2_19' : { /*要翻译的字符串*/ 'auto_detected' : '[url=store.steampowered.com]网站链接[/url]', /*自动检测*/ 'zh_CN' : '[url=store.steampowered.com]网站链接[/url]', /*简体*/ 'zh_TW' : '[url=store.steampowered.com]网站链接[/url]1', /*繁体*/ 'en_GB' : '[url=store.steampowered.com]网站链接[/url]2', /*英语*/ 'jp_JP' : '[url=store.steampowered.com]网站链接[/url]3' /*日语*/ }, 'class:localTool_2_20' : { /*要翻译的字符串*/ 'auto_detected' : '添加', /*自动检测*/ 'zh_CN' : '添加', /*简体*/ 'zh_TW' : '添加1', /*繁体*/ 'en_GB' : '添加2', /*英语*/ 'jp_JP' : '添加3' /*日语*/ }, 'class:localTool_2_21' : { /*要翻译的字符串*/ 'auto_detected' : '翻译模块(需要提前设置国籍):', /*自动检测*/ 'zh_CN' : '翻译模块(需要提前设置国籍):', /*简体*/ 'zh_TW' : '翻译模块(需要提前设置国籍):1', /*繁体*/ 'en_GB' : '翻译模块(需要提前设置国籍):2', /*英语*/ 'jp_JP' : '翻译模块(需要提前设置国籍):3' /*日语*/ }, 'class:localTool_2_22' : { /*要翻译的字符串*/ 'auto_detected' : '当前语言:', /*自动检测*/ 'zh_CN' : '当前语言:', /*简体*/ 'zh_TW' : '当前语言:1', /*繁体*/ 'en_GB' : '当前语言:2', /*英语*/ 'jp_JP' : '当前语言:3' /*日语*/ }, 'class:localTool_2_23' : { /*要翻译的字符串*/ 'auto_detected' : '自动检测', /*自动检测*/ 'zh_CN' : '自动检测', /*简体*/ 'zh_TW' : '自动检测1', /*繁体*/ 'en_GB' : '自动检测2', /*英语*/ 'jp_JP' : '自动检测3' /*日语*/ }, 'class:localTool_2_24' : { /*要翻译的字符串*/ 'auto_detected' : '中文简体', /*自动检测*/ 'zh_CN' : '中文简体', /*简体*/ 'zh_TW' : '中文简体1', /*繁体*/ 'en_GB' : '中文简体2', /*英语*/ 'jp_JP' : '中文简体3' /*日语*/ }, 'class:localTool_2_25' : { /*要翻译的字符串*/ 'auto_detected' : '英语', /*自动检测*/ 'zh_CN' : '英语', /*简体*/ 'zh_TW' : '英语1', /*繁体*/ 'en_GB' : '英语2', /*英语*/ 'jp_JP' : '英语3' /*日语*/ }, 'class:localTool_2_26' : { /*要翻译的字符串*/ 'auto_detected' : '日语', /*自动检测*/ 'zh_CN' : '日语', /*简体*/ 'zh_TW' : '日语1', /*繁体*/ 'en_GB' : '日语2', /*英语*/ 'jp_JP' : '日语3' /*日语*/ }, 'class:localTool_2_27' : { /*要翻译的字符串*/ 'auto_detected' : '目标语言:', /*自动检测*/ 'zh_CN' : '目标语言:', /*简体*/ 'zh_TW' : '目标语言:1', /*繁体*/ 'en_GB' : '目标语言:2', /*英语*/ 'jp_JP' : '目标语言:3' /*日语*/ }, 'class:localTool_2_28' : { /*要翻译的字符串*/ 'auto_detected' : '英语', /*自动检测*/ 'zh_CN' : '英语', /*简体*/ 'zh_TW' : '英语1', /*繁体*/ 'en_GB' : '英语2', /*英语*/ 'jp_JP' : '英语3' /*日语*/ }, 'class:localTool_2_29' : { /*要翻译的字符串*/ 'auto_detected' : '日语', /*自动检测*/ 'zh_CN' : '日语', /*简体*/ 'zh_TW' : '日语1', /*繁体*/ 'en_GB' : '日语2', /*英语*/ 'jp_JP' : '日语3' /*日语*/ }, 'class:localTool_2_30' : { /*要翻译的字符串*/ 'auto_detected' : '中文简体', /*自动检测*/ 'zh_CN' : '中文简体', /*简体*/ 'zh_TW' : '中文简体1', /*繁体*/ 'en_GB' : '中文简体2', /*英语*/ 'jp_JP' : '中文简体3' /*日语*/ }, 'class:localTool_2_31' : { /*要翻译的字符串*/ 'auto_detected' : '马新简体[zh-sg]', /*自动检测*/ 'zh_CN' : '马新简体[zh-sg]', /*简体*/ 'zh_TW' : '马新简体[zh-sg]1', /*繁体*/ 'en_GB' : '马新简体[zh-sg]2', /*英语*/ 'jp_JP' : '马新简体[zh-sg]3' /*日语*/ }, 'class:localTool_2_32' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文[zh-hant]', /*自动检测*/ 'zh_CN' : '繁體中文[zh-hant]', /*简体*/ 'zh_TW' : '繁體中文[zh-hant]1', /*繁体*/ 'en_GB' : '繁體中文[zh-hant]2', /*英语*/ 'jp_JP' : '繁體中文[zh-hant]3' /*日语*/ }, 'class:localTool_2_33' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文(香港)[zh-hk]', /*自动检测*/ 'zh_CN' : '繁體中文(香港)[zh-hk]', /*简体*/ 'zh_TW' : '繁體中文(香港)[zh-hk]1', /*繁体*/ 'en_GB' : '繁體中文(香港)[zh-hk]2', /*英语*/ 'jp_JP' : '繁體中文(香港)[zh-hk]3' /*日语*/ }, 'class:localTool_2_34' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文(澳门)[zh-mo]', /*自动检测*/ 'zh_CN' : '繁體中文(澳门)[zh-mo]', /*简体*/ 'zh_TW' : '繁體中文(澳门)[zh-mo]1', /*繁体*/ 'en_GB' : '繁體中文(澳门)[zh-mo]2', /*英语*/ 'jp_JP' : '繁體中文(澳门)[zh-mo]3' /*日语*/ }, 'class:localTool_2_35' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文(台湾)[zh-tw]', /*自动检测*/ 'zh_CN' : '繁體中文(台湾)[zh-tw]', /*简体*/ 'zh_TW' : '繁體中文(台湾)[zh-tw]1', /*繁体*/ 'en_GB' : '繁體中文(台湾)[zh-tw]2', /*英语*/ 'jp_JP' : '繁體中文(台湾)[zh-tw]3' /*日语*/ }, 'class:localTool_2_36' : { /*要翻译的字符串*/ 'auto_detected' : '翻译', /*自动检测*/ 'zh_CN' : '翻译', /*简体*/ 'zh_TW' : '翻译1', /*繁体*/ 'en_GB' : '翻译2', /*英语*/ 'jp_JP' : '翻译3' /*日语*/ }, 'class:localTool_2_37' : { /*要翻译的字符串*/ 'auto_detected' : '添加称呼模块(需要提前设置备注):', /*自动检测*/ 'zh_CN' : '添加称呼模块(需要提前设置备注):', /*简体*/ 'zh_TW' : '添加称呼模块(需要提前设置备注):1', /*繁体*/ 'en_GB' : '添加称呼模块(需要提前设置备注):2', /*英语*/ 'jp_JP' : '添加称呼模块(需要提前设置备注):3' /*日语*/ }, 'class:localTool_2_38' : { /*要翻译的字符串*/ 'auto_detected' : '自定义称呼模式', /*自动检测*/ 'zh_CN' : '自定义称呼模式', /*简体*/ 'zh_TW' : '自定义称呼模式1', /*繁体*/ 'en_GB' : '自定义称呼模式2', /*英语*/ 'jp_JP' : '自定义称呼模式3' /*日语*/ }, 'class:localTool_2_39' : { /*要翻译的字符串*/ 'auto_detected' : '在留言框添加自定义称呼标识符', /*自动检测*/ 'zh_CN' : '在留言框添加自定义称呼标识符', /*简体*/ 'zh_TW' : '在留言框添加自定义称呼标识符1', /*繁体*/ 'en_GB' : '在留言框添加自定义称呼标识符2', /*英语*/ 'jp_JP' : '在留言框添加自定义称呼标识符3' /*日语*/ }, 'class:localTool_2_40' : { /*要翻译的字符串*/ 'auto_detected' : '是否为组添加称呼(如果组没有备注则使用steam名称)', /*自动检测*/ 'zh_CN' : '是否为组添加称呼(如果组没有备注则使用steam名称)', /*简体*/ 'zh_TW' : '是否为组添加称呼(如果组没有备注则使用steam名称)1', /*繁体*/ 'en_GB' : '是否为组添加称呼(如果组没有备注则使用steam名称)2', /*英语*/ 'jp_JP' : '是否为组添加称呼(如果组没有备注则使用steam名称)3' /*日语*/ }, 'class:localTool_2_41' : { /*要翻译的字符串*/ 'auto_detected' : '是否为组添加称呼(如果组设置有备注则使用,否则不添加称呼)', /*自动检测*/ 'zh_TW' : '是否为组添加称呼(如果组设置有备注则使用,否则不添加称呼)1', /*繁体*/ 'en_GB' : '是否为组添加称呼(如果组设置有备注则使用,否则不添加称呼)2', /*英语*/ 'jp_JP' : '是否为组添加称呼(如果组设置有备注则使用,否则不添加称呼)3' /*日语*/ }, 'class:localTool_2_42' : { /*要翻译的字符串*/ 'auto_detected' : '格式化帮助', /*自动检测*/ 'zh_CN' : '格式化帮助', /*简体*/ 'zh_TW' : '格式化帮助1', /*繁体*/ 'en_GB' : '格式化帮助2', /*英语*/ 'jp_JP' : '格式化帮助3' /*日语*/ }, 'class:localTool_2_43' : { /*要翻译的字符串*/ 'auto_detected' : '发送评论给选择的组', /*自动检测*/ 'zh_CN' : '发送评论给选择的组', /*简体*/ 'zh_TW' : '发送评论给选择的组1', /*繁体*/ 'en_GB' : '发送评论给选择的组2', /*英语*/ 'jp_JP' : '发送评论给选择的组3' /*日语*/ }, 'class:localTool_2_44' : { /*要翻译的字符串*/ 'auto_detected' : '根据国籍发送评论给选择的组', /*自动检测*/ 'zh_CN' : '根据国籍发送评论给选择的组', /*简体*/ 'zh_TW' : '根据国籍发送评论给选择的组1', /*繁体*/ 'en_GB' : '根据国籍发送评论给选择的组2', /*英语*/ 'jp_JP' : '根据国籍发送评论给选择的组3' /*日语*/ }, 'class:localTool_2_45' : { /*要翻译的字符串*/ 'auto_detected' : '设置国籍:', /*自动检测*/ 'zh_CN' : '设置国籍:', /*简体*/ 'zh_TW' : '设置国籍:1', /*繁体*/ 'en_GB' : '设置国籍:2', /*英语*/ 'jp_JP' : '设置国籍:3' /*日语*/ }, 'class:localTool_2_46' : { /*要翻译的字符串*/ 'auto_detected' : '请选择要设置的国籍:', /*自动检测*/ 'zh_CN' : '请选择要设置的国籍:', /*简体*/ 'zh_TW' : '请选择要设置的国籍:1', /*繁体*/ 'en_GB' : '请选择要设置的国籍:2', /*英语*/ 'jp_JP' : '请选择要设置的国籍:3' /*日语*/ }, 'class:localTool_2_47' : { /*要翻译的字符串*/ 'auto_detected' : '简体中文', /*自动检测*/ 'zh_CN' : '简体中文', /*简体*/ 'zh_TW' : '简体中文1', /*繁体*/ 'en_GB' : '简体中文2', /*英语*/ 'jp_JP' : '简体中文3' /*日语*/ }, 'class:localTool_2_48' : { /*要翻译的字符串*/ 'auto_detected' : '英语', /*自动检测*/ 'zh_CN' : '英语', /*简体*/ 'zh_TW' : '英语1', /*繁体*/ 'en_GB' : '英语2', /*英语*/ 'jp_JP' : '英语3' /*日语*/ }, 'class:localTool_2_49' : { /*要翻译的字符串*/ 'auto_detected' : '日语', /*自动检测*/ 'zh_CN' : '日语', /*简体*/ 'zh_TW' : '日语1', /*繁体*/ 'en_GB' : '日语2', /*英语*/ 'jp_JP' : '日语3' /*日语*/ }, 'class:localTool_2_50' : { /*要翻译的字符串*/ 'auto_detected' : '马新简体(马来西亚,新加坡)[zh-sg]', /*自动检测*/ 'zh_CN' : '马新简体(马来西亚,新加坡)[zh-sg]', /*简体*/ 'zh_TW' : '马新简体(马来西亚,新加坡)[zh-sg]1', /*繁体*/ 'en_GB' : '马新简体(马来西亚,新加坡)[zh-sg]2', /*英语*/ 'jp_JP' : '马新简体(马来西亚,新加坡)[zh-sg]3' /*日语*/ }, 'class:localTool_2_51' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文[zh-hant]', /*自动检测*/ 'zh_CN' : '繁體中文[zh-hant]', /*简体*/ 'zh_TW' : '繁體中文[zh-hant]1', /*繁体*/ 'en_GB' : '繁體中文[zh-hant]2', /*英语*/ 'jp_JP' : '繁體中文[zh-hant]3' /*日语*/ }, 'class:localTool_2_52' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文(香港)[zh-hk]', /*自动检测*/ 'zh_CN' : '繁體中文(香港)[zh-hk]', /*简体*/ 'zh_TW' : '繁體中文(香港)[zh-hk]1', /*繁体*/ 'en_GB' : '繁體中文(香港)[zh-hk]2', /*英语*/ 'jp_JP' : '繁體中文(香港)[zh-hk]3' /*日语*/ }, 'class:localTool_2_53' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文(澳门)[zh-mo]', /*自动检测*/ 'zh_CN' : '繁體中文(澳门)[zh-mo]', /*简体*/ 'zh_TW' : '繁體中文(澳门)[zh-mo]1', /*繁体*/ 'en_GB' : '繁體中文(澳门)[zh-mo]2', /*英语*/ 'jp_JP' : '繁體中文(澳门)[zh-mo]3' /*日语*/ }, 'class:localTool_2_54' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文(台湾)[zh-tw]', /*自动检测*/ 'zh_CN' : '繁體中文(台湾)[zh-tw]', /*简体*/ 'zh_TW' : '繁體中文(台湾)[zh-tw]1', /*繁体*/ 'en_GB' : '繁體中文(台湾)[zh-tw]2', /*英语*/ 'jp_JP' : '繁體中文(台湾)[zh-tw]3' /*日语*/ }, 'class:localTool_2_55' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友设置国籍标识', /*自动检测*/ 'zh_CN' : '为选择的好友设置国籍标识', /*简体*/ 'zh_TW' : '为选择的好友设置国籍标识1', /*繁体*/ 'en_GB' : '为选择的好友设置国籍标识2', /*英语*/ 'jp_JP' : '为选择的好友设置国籍标识3' /*日语*/ }, 'class:localTool_2_56' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友取消国籍标识', /*自动检测*/ 'zh_CN' : '为选择的好友取消国籍标识', /*简体*/ 'zh_TW' : '为选择的好友取消国籍标识1', /*繁体*/ 'en_GB' : '为选择的好友取消国籍标识2', /*英语*/ 'jp_JP' : '为选择的好友取消国籍标识3' /*日语*/ }, 'class:localTool_2_57' : { /*要翻译的字符串*/ 'auto_detected' : '设置不留言:', /*自动检测*/ 'zh_CN' : '设置不留言:', /*简体*/ 'zh_TW' : '设置不留言:1', /*繁体*/ 'en_GB' : '设置不留言:2', /*英语*/ 'jp_JP' : '设置不留言:3' /*日语*/ }, 'class:localTool_2_58' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友设置不留言', /*自动检测*/ 'zh_CN' : '为选择的好友设置不留言', /*简体*/ 'zh_TW' : '为选择的好友设置不留言1', /*繁体*/ 'en_GB' : '为选择的好友设置不留言2', /*英语*/ 'jp_JP' : '为选择的好友设置不留言3' /*日语*/ }, 'class:localTool_2_59' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友取消设置不留言', /*自动检测*/ 'zh_CN' : '为选择的好友取消设置不留言', /*简体*/ 'zh_TW' : '为选择的好友取消设置不留言1', /*繁体*/ 'en_GB' : '为选择的好友取消设置不留言2', /*英语*/ 'jp_JP' : '为选择的好友取消设置不留言3' /*日语*/ }, 'class:localTool_2_60' : { /*要翻译的字符串*/ 'auto_detected' : '设置留言时间间隔:', /*自动检测*/ 'zh_CN' : '设置留言时间间隔:', /*简体*/ 'zh_TW' : '设置留言时间间隔:1', /*繁体*/ 'en_GB' : '设置留言时间间隔:2', /*英语*/ 'jp_JP' : '设置留言时间间隔:3' /*日语*/ }, 'class:localTool_2_61' : { /*要翻译的字符串*/ }, 'class:localTool_2_62' : { /*要翻译的字符串*/ }, 'class:localTool_2_63' : { /*要翻译的字符串*/ 'auto_detected' : '请选择留言', /*自动检测*/ 'zh_CN' : '请选择留言', /*简体*/ 'zh_TW' : '请选择留言1', /*繁体*/ 'en_GB' : '请选择留言2', /*英语*/ 'jp_JP' : '请选择留言3' /*日语*/ }, 'class:localTool_2_64' : { /*要翻译的字符串*/ 'auto_detected' : '留言日期差', /*自动检测*/ 'zh_CN' : '留言日期差', /*简体*/ 'zh_TW' : '留言日期差1', /*繁体*/ 'en_GB' : '留言日期差2', /*英语*/ 'jp_JP' : '留言日期差3' /*日语*/ }, 'class:localTool_2_65' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友设置留言时间间隔', /*自动检测*/ 'zh_CN' : '为选择的好友设置留言时间间隔', /*简体*/ 'zh_TW' : '为选择的好友设置留言时间间隔1', /*繁体*/ 'en_GB' : '为选择的好友设置留言时间间隔2', /*英语*/ 'jp_JP' : '为选择的好友设置留言时间间隔3' /*日语*/ }, 'class:localTool_2_66' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友取消设置留言时间间隔', /*自动检测*/ 'zh_CN' : '为选择的好友取消设置留言时间间隔', /*简体*/ 'zh_TW' : '为选择的好友取消设置留言时间间隔1', /*繁体*/ 'en_GB' : '为选择的好友取消设置留言时间间隔2', /*英语*/ 'jp_JP' : '为选择的好友取消设置留言时间间隔3' /*日语*/ }, 'class:localTool_2_67' : { /*要翻译的字符串*/ 'auto_detected' : '设置自动留言计划:', /*自动检测*/ 'zh_CN' : '设置自动留言计划:', /*简体*/ 'zh_TW' : '设置自动留言计划:1', /*繁体*/ 'en_GB' : '设置自动留言计划:2', /*英语*/ 'jp_JP' : '设置自动留言计划:3' /*日语*/ }, 'class:localTool_2_68' : { /*要翻译的字符串*/ 'auto_detected' : '请选择时间', /*自动检测*/ 'zh_CN' : '请选择时间', /*简体*/ 'zh_TW' : '请选择时间1', /*繁体*/ 'en_GB' : '请选择时间2', /*英语*/ 'jp_JP' : '请选择时间3' /*日语*/ }, 'class:localTool_2_69' : { /*要翻译的字符串*/ 'auto_detected' : '请选择时间', /*自动检测*/ 'zh_CN' : '请选择时间', /*简体*/ 'zh_TW' : '请选择时间1', /*繁体*/ 'en_GB' : '请选择时间2', /*英语*/ 'jp_JP' : '请选择时间3' /*日语*/ }, 'class:localTool_2_70' : { /*要翻译的字符串*/ 'auto_detected' : '设置好友分组:', /*自动检测*/ 'zh_CN' : '设置好友分组:', /*简体*/ 'zh_TW' : '设置好友分组:1', /*繁体*/ 'en_GB' : '设置好友分组:2', /*英语*/ 'jp_JP' : '设置好友分组:3' /*日语*/ }, 'class:localTool_2_71' : { /*要翻译的字符串*/ 'auto_detected' : '分组列表', /*自动检测*/ 'zh_CN' : '分组列表', /*简体*/ 'zh_TW' : '分组列表1', /*繁体*/ 'en_GB' : '分组列表2', /*英语*/ 'jp_JP' : '分组列表3' /*日语*/ }, 'class:localTool_2_72' : { /*要翻译的字符串*/ 'auto_detected' : '直接选择或搜索选择', /*自动检测*/ 'zh_CN' : '直接选择或搜索选择', /*简体*/ 'zh_TW' : '直接选择或搜索选择1', /*繁体*/ 'en_GB' : '直接选择或搜索选择2', /*英语*/ 'jp_JP' : '直接选择或搜索选择3' /*日语*/ }, 'class:localTool_2_73' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_2_74' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_2_75' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_2_76' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_2_77' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_2_78' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_2_79' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_2_80' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_2_81' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_2_82' : { /*要翻译的字符串*/ 'auto_detected' : '编辑列表', /*自动检测*/ 'zh_CN' : '编辑列表', /*简体*/ 'zh_TW' : '编辑列表1', /*繁体*/ 'en_GB' : '编辑列表2', /*英语*/ 'jp_JP' : '编辑列表3' /*日语*/ }, 'class:localTool_2_83' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友添加分组', /*自动检测*/ 'zh_CN' : '为选择的好友添加分组', /*简体*/ 'zh_TW' : '为选择的好友添加分组1', /*繁体*/ 'en_GB' : '为选择的好友添加分组2', /*英语*/ 'jp_JP' : '为选择的好友添加分组3' /*日语*/ }, 'class:localTool_2_84' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友取消添加分组', /*自动检测*/ 'zh_CN' : '为选择的好友取消添加分组', /*简体*/ 'zh_TW' : '为选择的好友取消添加分组1', /*繁体*/ 'en_GB' : '为选择的好友取消添加分组2', /*英语*/ 'jp_JP' : '为选择的好友取消添加分组3' /*日语*/ }, 'class:localTool_2_85' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_2_86' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_2_87' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_2_88' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_2_89' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_2_90' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_2_91' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_2_92' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_2_93' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_2_94' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_2_95' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_2_96' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_2_97' : { /*要翻译的字符串*/ 'auto_detected' : '按国籍进行高亮分组', /*自动检测*/ 'zh_CN' : '按国籍进行高亮分组', /*简体*/ 'zh_TW' : '按国籍进行高亮分组1', /*繁体*/ 'en_GB' : '按国籍进行高亮分组2', /*英语*/ 'jp_JP' : '按国籍进行高亮分组3' /*日语*/ }, 'class:localTool_2_98' : { /*要翻译的字符串*/ 'auto_detected' : '按国籍进行排序分组(慢)', /*自动检测*/ 'zh_CN' : '按国籍进行排序分组(慢)', /*简体*/ 'zh_TW' : '按国籍进行排序分组(慢)1', /*繁体*/ 'en_GB' : '按国籍进行排序分组(慢)2', /*英语*/ 'jp_JP' : '按国籍进行排序分组(慢)3' /*日语*/ }, 'class:localTool_2_99' : { /*要翻译的字符串*/ 'auto_detected' : '按在线时间进行排序分组', /*自动检测*/ 'zh_CN' : '按在线时间进行排序分组', /*简体*/ 'zh_TW' : '按在线时间进行排序分组1', /*繁体*/ 'en_GB' : '按在线时间进行排序分组2', /*英语*/ 'jp_JP' : '按在线时间进行排序分组3' /*日语*/ }, 'class:localTool_2_100' : { /*要翻译的字符串*/ 'auto_detected' : '显示好友详细数据-不可用', /*自动检测*/ 'zh_CN' : '显示好友详细数据-不可用', /*简体*/ 'zh_TW' : '显示好友详细数据-不可用1', /*繁体*/ 'en_GB' : '显示好友详细数据-不可用2', /*英语*/ 'jp_JP' : '显示好友详细数据-不可用3' /*日语*/ }, 'class:localTool_2_101' : { /*要翻译的字符串*/ 'auto_detected' : '好友数据统计', /*自动检测*/ 'zh_CN' : '好友数据统计', /*简体*/ 'zh_TW' : '好友数据统计1', /*繁体*/ 'en_GB' : '好友数据统计2', /*英语*/ 'jp_JP' : '好友数据统计3' /*日语*/ }, 'class:localTool_2_102' : { /*要翻译的字符串*/ 'auto_detected' : '留言数据统计', /*自动检测*/ 'zh_CN' : '留言数据统计', /*简体*/ 'zh_TW' : '留言数据统计1', /*繁体*/ 'en_GB' : '留言数据统计2', /*英语*/ 'jp_JP' : '留言数据统计3' /*日语*/ }, 'class:localTool_2_103' : { /*要翻译的字符串*/ 'auto_detected' : '关系网统计', /*自动检测*/ 'zh_CN' : '关系网统计', /*简体*/ 'zh_TW' : '关系网统计1', /*繁体*/ 'en_GB' : '关系网统计2', /*英语*/ 'jp_JP' : '关系网统计3' /*日语*/ }, 'class:localTool_2_104' : { /*要翻译的字符串*/ 'auto_detected' : '当前配置统计', /*自动检测*/ 'zh_CN' : '当前配置统计', /*简体*/ 'zh_TW' : '当前配置统计1', /*繁体*/ 'en_GB' : '当前配置统计2', /*英语*/ 'jp_JP' : '当前配置统计3' /*日语*/ }, 'class:localTool_2_105' : { /*要翻译的字符串*/ 'auto_detected' : '查看好友配置统计', /*自动检测*/ 'zh_CN' : '查看好友配置统计', /*简体*/ 'zh_TW' : '查看好友配置统计1', /*繁体*/ 'en_GB' : '查看好友配置统计2', /*英语*/ 'jp_JP' : '查看好友配置统计3' /*日语*/ }, 'class:localTool_2_106' : { /*要翻译的字符串*/ 'auto_detected' : '数据表格(汇总所有的数据:id,名称,备注,国籍(语言),等级,好友数量,游戏数量,dlc数量,创意工坊数量,艺术作品数量,动态数量)', /*自动检测*/ }, 'class:localTool_2_107' : { /*要翻译的字符串*/ 'auto_detected' : '分为:', /*自动检测*/ 'zh_CN' : '分为:', /*简体*/ 'zh_TW' : '分为:1', /*繁体*/ 'en_GB' : '分为:2', /*英语*/ 'jp_JP' : '分为:3' /*日语*/ }, 'class:localTool_2_108' : { /*要翻译的字符串*/ 'auto_detected' : '按国籍的饼图(总留言数量),', /*自动检测*/ 'zh_CN' : '按国籍的饼图(总留言数量),', /*简体*/ 'zh_TW' : '按国籍的饼图(总留言数量),1', /*繁体*/ 'en_GB' : '按国籍的饼图(总留言数量),2', /*英语*/ 'jp_JP' : '按国籍的饼图(总留言数量),3' /*日语*/ }, 'class:localTool_2_109' : { /*要翻译的字符串*/ 'auto_detected' : '按每天留言数据的折线图(统计所有的留言数据,生成的折线图),', /*自动检测*/ }, 'class:localTool_2_110' : { /*要翻译的字符串*/ }, 'class:localTool_2_111' : { /*要翻译的字符串*/ 'auto_detected' : '数据表格(汇总所有的数据)', /*自动检测*/ 'zh_CN' : '数据表格(汇总所有的数据)', /*简体*/ 'zh_TW' : '数据表格(汇总所有的数据)1', /*繁体*/ 'en_GB' : '数据表格(汇总所有的数据)2', /*英语*/ 'jp_JP' : '数据表格(汇总所有的数据)3' /*日语*/ }, 'class:localTool_2_112' : { /*要翻译的字符串*/ 'auto_detected' : '好友关系网(仅统计共同好友)', /*自动检测*/ 'zh_CN' : '好友关系网(仅统计共同好友)', /*简体*/ 'zh_TW' : '好友关系网(仅统计共同好友)1', /*繁体*/ 'en_GB' : '好友关系网(仅统计共同好友)2', /*英语*/ 'jp_JP' : '好友关系网(仅统计共同好友)3' /*日语*/ }, 'class:localTool_2_113' : { /*要翻译的字符串*/ 'auto_detected' : '当前的配置数据和运行状态', /*自动检测*/ 'zh_CN' : '当前的配置数据和运行状态', /*简体*/ 'zh_TW' : '当前的配置数据和运行状态1', /*繁体*/ 'en_GB' : '当前的配置数据和运行状态2', /*英语*/ 'jp_JP' : '当前的配置数据和运行状态3' /*日语*/ }, 'class:localTool_2_114' : { /*要翻译的字符串*/ 'auto_detected' : '对好友设置的配置数据(比如国籍,不留言,留言时间间隔等)', /*自动检测*/ 'zh_CN' : '对好友设置的配置数据(比如国籍,不留言,留言时间间隔等)', /*简体*/ 'zh_TW' : '对好友设置的配置数据(比如国籍,不留言,留言时间间隔等)1', /*繁体*/ 'en_GB' : '对好友设置的配置数据(比如国籍,不留言,留言时间间隔等)2', /*英语*/ 'jp_JP' : '对好友设置的配置数据(比如国籍,不留言,留言时间间隔等)3' /*日语*/ }, 'class:localTool_2_115' : { /*要翻译的字符串*/ 'auto_detected' : '动态点赞助手', /*自动检测*/ 'zh_CN' : '动态点赞助手', /*简体*/ 'zh_TW' : '动态点赞助手1', /*繁体*/ 'en_GB' : '动态点赞助手2', /*英语*/ 'jp_JP' : '动态点赞助手3' /*日语*/ }, 'class:localTool_2_116' : { /*要翻译的字符串*/ 'auto_detected' : '总开关', /*自动检测*/ 'zh_CN' : '总开关', /*简体*/ 'zh_TW' : '总开关1', /*繁体*/ 'en_GB' : '总开关2', /*英语*/ 'jp_JP' : '总开关3' /*日语*/ }, 'class:localTool_2_117' : { /*要翻译的字符串*/ 'auto_detected' : '设置点赞内容:', /*自动检测*/ 'zh_CN' : '设置点赞内容:', /*简体*/ 'zh_TW' : '设置点赞内容:1', /*繁体*/ 'en_GB' : '设置点赞内容:2', /*英语*/ 'jp_JP' : '设置点赞内容:3' /*日语*/ }, 'class:localTool_2_118' : { /*要翻译的字符串*/ 'auto_detected' : '点赞内容:', /*自动检测*/ 'zh_CN' : '点赞内容:', /*简体*/ 'zh_TW' : '点赞内容:1', /*繁体*/ 'en_GB' : '点赞内容:2', /*英语*/ 'jp_JP' : '点赞内容:3' /*日语*/ }, 'class:localTool_2_119' : { /*要翻译的字符串*/ 'auto_detected' : '设置自动点赞模式:', /*自动检测*/ 'zh_CN' : '设置自动点赞模式:', /*简体*/ 'zh_TW' : '设置自动点赞模式:1', /*繁体*/ 'en_GB' : '设置自动点赞模式:2', /*英语*/ 'jp_JP' : '设置自动点赞模式:3' /*日语*/ }, 'class:localTool_2_120' : { /*要翻译的字符串*/ 'auto_detected' : '点赞模式:', /*自动检测*/ 'zh_CN' : '点赞模式:', /*简体*/ 'zh_TW' : '点赞模式:1', /*繁体*/ 'en_GB' : '点赞模式:2', /*英语*/ 'jp_JP' : '点赞模式:3' /*日语*/ }, 'class:localTool_2_121' : { /*要翻译的字符串*/ 'auto_detected' : '设置自动点赞时间区间(默认今天~之前所有的动态内容)', /*自动检测*/ 'zh_CN' : '设置自动点赞时间区间(默认今天~之前所有的动态内容)', /*简体*/ 'zh_TW' : '设置自动点赞时间区间(默认今天~之前所有的动态内容)1', /*繁体*/ 'en_GB' : '设置自动点赞时间区间(默认今天~之前所有的动态内容)2', /*英语*/ 'jp_JP' : '设置自动点赞时间区间(默认今天~之前所有的动态内容)3' /*日语*/ }, 'class:localTool_2_122' : { /*要翻译的字符串*/ 'auto_detected' : '请选择范围', /*自动检测*/ 'zh_CN' : '请选择范围', /*简体*/ 'zh_TW' : '请选择范围1', /*繁体*/ 'en_GB' : '请选择范围2', /*英语*/ 'jp_JP' : '请选择范围3' /*日语*/ }, 'class:localTool_2_123' : { /*要翻译的字符串*/ 'auto_detected' : '点赞进度时间线', /*自动检测*/ 'zh_CN' : '点赞进度时间线', /*简体*/ 'zh_TW' : '点赞进度时间线1', /*繁体*/ 'en_GB' : '点赞进度时间线2', /*英语*/ 'jp_JP' : '点赞进度时间线3' /*日语*/ }, 'class:localTool_2_124' : { /*要翻译的字符串*/ 'auto_detected' : '', /*自动检测*/ 'zh_CN' : '', /*简体*/ 'zh_TW' : '1', /*繁体*/ 'en_GB' : '2', /*英语*/ 'jp_JP' : '3' /*日语*/ }, 'class:localTool_2_125' : { /*要翻译的字符串*/ 'auto_detected' : '8月18日', /*自动检测*/ 'zh_CN' : '8月18日', /*简体*/ 'zh_TW' : '8月18日1', /*繁体*/ 'en_GB' : '8月18日2', /*英语*/ 'jp_JP' : '8月18日3' /*日语*/ }, 'class:localTool_2_126' : { /*要翻译的字符串*/ 'auto_detected' : '已点赞状态x条,点赞发布艺术作品x条,点赞收藏艺术作品x条', /*自动检测*/ 'zh_CN' : '已点赞状态x条,点赞发布艺术作品x条,点赞收藏艺术作品x条', /*简体*/ 'zh_TW' : '已点赞状态x条,点赞发布艺术作品x条,点赞收藏艺术作品x条1', /*繁体*/ 'en_GB' : '已点赞状态x条,点赞发布艺术作品x条,点赞收藏艺术作品x条2', /*英语*/ 'jp_JP' : '已点赞状态x条,点赞发布艺术作品x条,点赞收藏艺术作品x条3' /*日语*/ }, 'class:localTool_2_127' : { /*要翻译的字符串*/ 'auto_detected' : '已点赞评测x条,点赞发布创意工坊x条,点赞收藏创意工坊x条', /*自动检测*/ 'zh_CN' : '已点赞评测x条,点赞发布创意工坊x条,点赞收藏创意工坊x条', /*简体*/ 'zh_TW' : '已点赞评测x条,点赞发布创意工坊x条,点赞收藏创意工坊x条1', /*繁体*/ 'en_GB' : '已点赞评测x条,点赞发布创意工坊x条,点赞收藏创意工坊x条2', /*英语*/ 'jp_JP' : '已点赞评测x条,点赞发布创意工坊x条,点赞收藏创意工坊x条3' /*日语*/ }, 'class:localTool_2_128' : { /*要翻译的字符串*/ 'auto_detected' : '已点赞购买状态x条,点赞发布指南x条,点赞收藏指南x条', /*自动检测*/ 'zh_CN' : '已点赞购买状态x条,点赞发布指南x条,点赞收藏指南x条', /*简体*/ 'zh_TW' : '已点赞购买状态x条,点赞发布指南x条,点赞收藏指南x条1', /*繁体*/ 'en_GB' : '已点赞购买状态x条,点赞发布指南x条,点赞收藏指南x条2', /*英语*/ 'jp_JP' : '已点赞购买状态x条,点赞发布指南x条,点赞收藏指南x条3' /*日语*/ }, 'class:localTool_2_129' : { /*要翻译的字符串*/ 'auto_detected' : '已点赞组通知x条,点赞上次载图x条,点赞收藏载图x条', /*自动检测*/ 'zh_CN' : '已点赞组通知x条,点赞上次载图x条,点赞收藏载图x条', /*简体*/ 'zh_TW' : '已点赞组通知x条,点赞上次载图x条,点赞收藏载图x条1', /*繁体*/ 'en_GB' : '已点赞组通知x条,点赞上次载图x条,点赞收藏载图x条2', /*英语*/ 'jp_JP' : '已点赞组通知x条,点赞上次载图x条,点赞收藏载图x条3' /*日语*/ }, 'class:localTool_2_130' : { /*要翻译的字符串*/ 'auto_detected' : '已点赞组活动x条,点赞上传视频x条,点赞收藏视频x条', /*自动检测*/ 'zh_CN' : '已点赞组活动x条,点赞上传视频x条,点赞收藏视频x条', /*简体*/ 'zh_TW' : '已点赞组活动x条,点赞上传视频x条,点赞收藏视频x条1', /*繁体*/ 'en_GB' : '已点赞组活动x条,点赞上传视频x条,点赞收藏视频x条2', /*英语*/ 'jp_JP' : '已点赞组活动x条,点赞上传视频x条,点赞收藏视频x条3' /*日语*/ }, 'class:localTool_2_131' : { /*要翻译的字符串*/ 'auto_detected' : '', /*自动检测*/ 'zh_CN' : '', /*简体*/ 'zh_TW' : '1', /*繁体*/ 'en_GB' : '2', /*英语*/ 'jp_JP' : '3' /*日语*/ }, 'class:localTool_2_132' : { /*要翻译的字符串*/ 'auto_detected' : '8月16日', /*自动检测*/ 'zh_CN' : '8月16日', /*简体*/ 'zh_TW' : '8月16日1', /*繁体*/ 'en_GB' : '8月16日2', /*英语*/ 'jp_JP' : '8月16日3' /*日语*/ }, 'class:localTool_2_133' : { /*要翻译的字符串*/ }, 'class:localTool_2_134' : { /*要翻译的字符串*/ 'auto_detected' : '《登高》', /*自动检测*/ 'zh_CN' : '《登高》', /*简体*/ 'zh_TW' : '《登高》1', /*繁体*/ 'en_GB' : '《登高》2', /*英语*/ 'jp_JP' : '《登高》3' /*日语*/ }, 'class:localTool_2_135' : { /*要翻译的字符串*/ 'auto_detected' : '《茅屋为秋风所破歌》', /*自动检测*/ 'zh_CN' : '《茅屋为秋风所破歌》', /*简体*/ 'zh_TW' : '《茅屋为秋风所破歌》1', /*繁体*/ 'en_GB' : '《茅屋为秋风所破歌》2', /*英语*/ 'jp_JP' : '《茅屋为秋风所破歌》3' /*日语*/ }, 'class:localTool_2_136' : { /*要翻译的字符串*/ 'auto_detected' : '', /*自动检测*/ 'zh_CN' : '', /*简体*/ 'zh_TW' : '1', /*繁体*/ 'en_GB' : '2', /*英语*/ 'jp_JP' : '3' /*日语*/ }, 'class:localTool_2_137' : { /*要翻译的字符串*/ 'auto_detected' : '8月15日', /*自动检测*/ 'zh_CN' : '8月15日', /*简体*/ 'zh_TW' : '8月15日1', /*繁体*/ 'en_GB' : '8月15日2', /*英语*/ 'jp_JP' : '8月15日3' /*日语*/ }, 'class:localTool_2_138' : { /*要翻译的字符串*/ 'auto_detected' : '中国人民抗日战争胜利日', /*自动检测*/ 'zh_CN' : '中国人民抗日战争胜利日', /*简体*/ 'zh_TW' : '中国人民抗日战争胜利日1', /*繁体*/ 'en_GB' : '中国人民抗日战争胜利日2', /*英语*/ 'jp_JP' : '中国人民抗日战争胜利日3' /*日语*/ }, 'class:localTool_2_139' : { /*要翻译的字符串*/ }, 'class:localTool_2_140' : { /*要翻译的字符串*/ 'auto_detected' : '铭记、感恩', /*自动检测*/ 'zh_CN' : '铭记、感恩', /*简体*/ 'zh_TW' : '铭记、感恩1', /*繁体*/ 'en_GB' : '铭记、感恩2', /*英语*/ 'jp_JP' : '铭记、感恩3' /*日语*/ }, 'class:localTool_2_141' : { /*要翻译的字符串*/ 'auto_detected' : '所有为中华民族浴血奋战的英雄将士', /*自动检测*/ 'zh_CN' : '所有为中华民族浴血奋战的英雄将士', /*简体*/ 'zh_TW' : '所有为中华民族浴血奋战的英雄将士1', /*繁体*/ 'en_GB' : '所有为中华民族浴血奋战的英雄将士2', /*英语*/ 'jp_JP' : '所有为中华民族浴血奋战的英雄将士3' /*日语*/ }, 'class:localTool_2_142' : { /*要翻译的字符串*/ 'auto_detected' : '永垂不朽', /*自动检测*/ 'zh_CN' : '永垂不朽', /*简体*/ 'zh_TW' : '永垂不朽1', /*繁体*/ 'en_GB' : '永垂不朽2', /*英语*/ 'jp_JP' : '永垂不朽3' /*日语*/ }, 'class:localTool_2_143' : { /*要翻译的字符串*/ 'auto_detected' : '', /*自动检测*/ 'zh_CN' : '', /*简体*/ 'zh_TW' : '1', /*繁体*/ 'en_GB' : '2', /*英语*/ 'jp_JP' : '3' /*日语*/ }, 'class:localTool_2_144' : { /*要翻译的字符串*/ 'auto_detected' : '过去', /*自动检测*/ 'zh_CN' : '过去', /*简体*/ 'zh_TW' : '过去1', /*繁体*/ 'en_GB' : '过去2', /*英语*/ 'jp_JP' : '过去3' /*日语*/ }, 'class:localTool_2_145' : { /*要翻译的字符串*/ 'auto_detected' : '喜加一助手', /*自动检测*/ 'zh_CN' : '喜加一助手', /*简体*/ 'zh_TW' : '喜加一助手1', /*繁体*/ 'en_GB' : '喜加一助手2', /*英语*/ 'jp_JP' : '喜加一助手3' /*日语*/ }, 'class:localTool_2_146' : { /*要翻译的字符串*/ 'auto_detected' : '总开关', /*自动检测*/ 'zh_CN' : '总开关', /*简体*/ 'zh_TW' : '总开关1', /*繁体*/ 'en_GB' : '总开关2', /*英语*/ 'jp_JP' : '总开关3' /*日语*/ }, 'class:localTool_2_147' : { /*要翻译的字符串*/ 'auto_detected' : '设置:', /*自动检测*/ 'zh_CN' : '设置:', /*简体*/ 'zh_TW' : '设置:1', /*繁体*/ 'en_GB' : '设置:2', /*英语*/ 'jp_JP' : '设置:3' /*日语*/ }, 'class:localTool_2_148' : { /*要翻译的字符串*/ 'auto_detected' : '设置喜加一数据来源', /*自动检测*/ 'zh_CN' : '设置喜加一数据来源', /*简体*/ 'zh_TW' : '设置喜加一数据来源1', /*繁体*/ 'en_GB' : '设置喜加一数据来源2', /*英语*/ 'jp_JP' : '设置喜加一数据来源3' /*日语*/ }, 'class:localTool_2_149' : { /*要翻译的字符串*/ 'auto_detected' : '设置:', /*自动检测*/ 'zh_CN' : '设置:', /*简体*/ 'zh_TW' : '设置:1', /*繁体*/ 'en_GB' : '设置:2', /*英语*/ 'jp_JP' : '设置:3' /*日语*/ }, 'class:localTool_2_150' : { /*要翻译的字符串*/ 'auto_detected' : '功能设置', /*自动检测*/ 'zh_CN' : '功能设置', /*简体*/ 'zh_TW' : '功能设置1', /*繁体*/ 'en_GB' : '功能设置2', /*英语*/ 'jp_JP' : '功能设置3' /*日语*/ }, 'class:localTool_2_151' : { /*要翻译的字符串*/ 'auto_detected' : 'Debug模式', /*自动检测*/ 'zh_CN' : 'Debug模式', /*简体*/ 'zh_TW' : 'Debug模式1', /*繁体*/ 'en_GB' : 'Debug模式2', /*英语*/ 'jp_JP' : 'Debug模式3' /*日语*/ }, 'class:localTool_2_152' : { /*要翻译的字符串*/ 'auto_detected' : '弹出层', /*自动检测*/ 'zh_CN' : '弹出层', /*简体*/ 'zh_TW' : '弹出层1', /*繁体*/ 'en_GB' : '弹出层2', /*英语*/ 'jp_JP' : '弹出层3' /*日语*/ }, 'class:localTool_2_153' : { /*要翻译的字符串*/ 'auto_detected' : '滑块', /*自动检测*/ 'zh_CN' : '滑块', /*简体*/ 'zh_TW' : '滑块1', /*繁体*/ 'en_GB' : '滑块2', /*英语*/ 'jp_JP' : '滑块3' /*日语*/ }, 'class:localTool_2_154' : { /*要翻译的字符串*/ 'auto_detected' : '导入导出重置当前设置', /*自动检测*/ 'zh_CN' : '导入导出重置当前设置', /*简体*/ 'zh_TW' : '导入导出重置当前设置1', /*繁体*/ 'en_GB' : '导入导出重置当前设置2', /*英语*/ 'jp_JP' : '导入导出重置当前设置3' /*日语*/ }, 'class:localTool_2_155' : { /*要翻译的字符串*/ 'auto_detected' : '弹出层', /*自动检测*/ 'zh_CN' : '弹出层', /*简体*/ 'zh_TW' : '弹出层1', /*繁体*/ 'en_GB' : '弹出层2', /*英语*/ 'jp_JP' : '弹出层3' /*日语*/ }, 'class:localTool_2_156' : { /*要翻译的字符串*/ 'auto_detected' : '', /*自动检测*/ 'zh_CN' : '', /*简体*/ 'zh_TW' : '1', /*繁体*/ 'en_GB' : '2', /*英语*/ 'jp_JP' : '3' /*日语*/ }, 'class:localTool_2_157' : { /*要翻译的字符串*/ 'auto_detected' : '点击上传,或将文件拖拽到此处', /*自动检测*/ 'zh_CN' : '点击上传,或将文件拖拽到此处', /*简体*/ 'zh_TW' : '点击上传,或将文件拖拽到此处1', /*繁体*/ 'en_GB' : '点击上传,或将文件拖拽到此处2', /*英语*/ 'jp_JP' : '点击上传,或将文件拖拽到此处3' /*日语*/ }, 'class:localTool_2_158' : { /*要翻译的字符串*/ 'auto_detected' : '界面设置', /*自动检测*/ 'zh_CN' : '界面设置', /*简体*/ 'zh_TW' : '界面设置1', /*繁体*/ 'en_GB' : '界面设置2', /*英语*/ 'jp_JP' : '界面设置3' /*日语*/ }, 'class:localTool_2_159' : { /*要翻译的字符串*/ 'auto_detected' : '语言配置', /*自动检测*/ 'zh_CN' : '语言配置', /*简体*/ 'zh_TW' : '语言配置1', /*繁体*/ 'en_GB' : '语言配置2', /*英语*/ 'jp_JP' : '语言配置3' /*日语*/ }, 'class:localTool_2_160' : { /*要翻译的字符串*/ 'auto_detected' : '自动检测(简体中文)', /*自动检测*/ 'zh_CN' : '自动检测(简体中文)', /*简体*/ 'zh_TW' : '自动检测(简体中文)1', /*繁体*/ 'en_GB' : '自动检测(简体中文)2', /*英语*/ 'jp_JP' : '自动检测(简体中文)3' /*日语*/ }, 'class:localTool_2_161' : { /*要翻译的字符串*/ 'auto_detected' : '简体中文', /*自动检测*/ 'zh_CN' : '简体中文', /*简体*/ 'zh_TW' : '简体中文1', /*繁体*/ 'en_GB' : '简体中文2', /*英语*/ 'jp_JP' : '简体中文3' /*日语*/ }, 'class:localTool_2_162' : { /*要翻译的字符串*/ 'auto_detected' : '繁体中文', /*自动检测*/ 'zh_CN' : '繁体中文', /*简体*/ 'zh_TW' : '繁体中文1', /*繁体*/ 'en_GB' : '繁体中文2', /*英语*/ 'jp_JP' : '繁体中文3' /*日语*/ }, 'class:localTool_2_163' : { /*要翻译的字符串*/ 'auto_detected' : 'English', /*自动检测*/ 'zh_CN' : 'English', /*简体*/ 'zh_TW' : 'English1', /*繁体*/ 'en_GB' : 'English2', /*英语*/ 'jp_JP' : 'English3' /*日语*/ }, 'class:localTool_2_164' : { /*要翻译的字符串*/ 'auto_detected' : '主题切换', /*自动检测*/ 'zh_CN' : '主题切换', /*简体*/ 'zh_TW' : '主题切换1', /*繁体*/ 'en_GB' : '主题切换2', /*英语*/ 'jp_JP' : '主题切换3' /*日语*/ }, 'class:localTool_2_165' : { /*要翻译的字符串*/ 'auto_detected' : '请选择一个主题,然后点击应用', /*自动检测*/ 'zh_CN' : '请选择一个主题,然后点击应用', /*简体*/ 'zh_TW' : '请选择一个主题,然后点击应用1', /*繁体*/ 'en_GB' : '请选择一个主题,然后点击应用2', /*英语*/ 'jp_JP' : '请选择一个主题,然后点击应用3' /*日语*/ }, 'class:localTool_2_166' : { /*要翻译的字符串*/ 'auto_detected' : '应用主题', /*自动检测*/ 'zh_CN' : '应用主题', /*简体*/ 'zh_TW' : '应用主题1', /*繁体*/ 'en_GB' : '应用主题2', /*英语*/ 'jp_JP' : '应用主题3' /*日语*/ }, 'class:localTool_2_167' : { /*要翻译的字符串*/ 'auto_detected' : 'UI设置', /*自动检测*/ 'zh_CN' : 'UI设置', /*简体*/ 'zh_TW' : 'UI设置1', /*繁体*/ 'en_GB' : 'UI设置2', /*英语*/ 'jp_JP' : 'UI设置3' /*日语*/ }, 'class:localTool_2_168' : { /*要翻译的字符串*/ 'auto_detected' : '预览:', /*自动检测*/ 'zh_CN' : '预览:', /*简体*/ 'zh_TW' : '预览:1', /*繁体*/ 'en_GB' : '预览:2', /*英语*/ 'jp_JP' : '预览:3' /*日语*/ }, 'class:localTool_2_169' : { /*要翻译的字符串*/ 'auto_detected' : '主要字体颜色:', /*自动检测*/ 'zh_CN' : '主要字体颜色:', /*简体*/ 'zh_TW' : '主要字体颜色:1', /*繁体*/ 'en_GB' : '主要字体颜色:2', /*英语*/ 'jp_JP' : '主要字体颜色:3' /*日语*/ }, 'class:localTool_2_170' : { /*要翻译的字符串*/ 'auto_detected' : '主要背景颜色:', /*自动检测*/ 'zh_CN' : '主要背景颜色:', /*简体*/ 'zh_TW' : '主要背景颜色:1', /*繁体*/ 'en_GB' : '主要背景颜色:2', /*英语*/ 'jp_JP' : '主要背景颜色:3' /*日语*/ }, 'class:localTool_2_171' : { /*要翻译的字符串*/ 'auto_detected' : '留言成功字体颜色:', /*自动检测*/ 'zh_CN' : '留言成功字体颜色:', /*简体*/ 'zh_TW' : '留言成功字体颜色:1', /*繁体*/ 'en_GB' : '留言成功字体颜色:2', /*英语*/ 'jp_JP' : '留言成功字体颜色:3' /*日语*/ }, 'class:localTool_2_172' : { /*要翻译的字符串*/ 'auto_detected' : '留言失败字体颜色:', /*自动检测*/ 'zh_CN' : '留言失败字体颜色:', /*简体*/ 'zh_TW' : '留言失败字体颜色:1', /*繁体*/ 'en_GB' : '留言失败字体颜色:2', /*英语*/ 'jp_JP' : '留言失败字体颜色:3' /*日语*/ }, 'class:localTool_2_173' : { /*要翻译的字符串*/ 'auto_detected' : '留言发生错误字体颜色:', /*自动检测*/ 'zh_CN' : '留言发生错误字体颜色:', /*简体*/ 'zh_TW' : '留言发生错误字体颜色:1', /*繁体*/ 'en_GB' : '留言发生错误字体颜色:2', /*英语*/ 'jp_JP' : '留言发生错误字体颜色:3' /*日语*/ }, 'class:localTool_2_174' : { /*要翻译的字符串*/ 'auto_detected' : '保存为主题', /*自动检测*/ 'zh_CN' : '保存为主题', /*简体*/ 'zh_TW' : '保存为主题1', /*繁体*/ 'en_GB' : '保存为主题2', /*英语*/ 'jp_JP' : '保存为主题3' /*日语*/ }, 'class:localTool_2_175' : { /*要翻译的字符串*/ 'auto_detected' : '关于SteamAssistant(Steam小助手)', /*自动检测*/ 'zh_CN' : '关于SteamAssistant(Steam小助手)', /*简体*/ 'zh_TW' : '关于SteamAssistant(Steam小助手)1', /*繁体*/ 'en_GB' : '关于SteamAssistant(Steam小助手)2', /*英语*/ 'jp_JP' : '关于SteamAssistant(Steam小助手)3' /*日语*/ }, 'class:localTool_2_176' : { /*要翻译的字符串*/ 'auto_detected' : '程序信息:', /*自动检测*/ 'zh_CN' : '程序信息:', /*简体*/ 'zh_TW' : '程序信息:1', /*繁体*/ 'en_GB' : '程序信息:2', /*英语*/ 'jp_JP' : '程序信息:3' /*日语*/ }, 'class:localTool_2_177' : { /*要翻译的字符串*/ 'auto_detected' : '当前版本:v0.2.3.0', /*自动检测*/ 'zh_CN' : '当前版本:v0.2.3.0', /*简体*/ 'zh_TW' : '当前版本:v0.2.3.01', /*繁体*/ 'en_GB' : '当前版本:v0.2.3.02', /*英语*/ 'jp_JP' : '当前版本:v0.2.3.03' /*日语*/ }, 'class:localTool_2_178' : { /*要翻译的字符串*/ 'auto_detected' : '主程序框架更新时间:2020年4月19日', /*自动检测*/ 'zh_CN' : '主程序框架更新时间:2020年4月19日', /*简体*/ 'zh_TW' : '主程序框架更新时间:2020年4月19日1', /*繁体*/ 'en_GB' : '主程序框架更新时间:2020年4月19日2', /*英语*/ 'jp_JP' : '主程序框架更新时间:2020年4月19日3' /*日语*/ }, 'class:localTool_2_179' : { /*要翻译的字符串*/ 'auto_detected' : 'common模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'common模块:2020年4月19日', /*简体*/ 'zh_TW' : 'common模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'common模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'common模块:2020年4月19日3' /*日语*/ }, 'class:localTool_2_180' : { /*要翻译的字符串*/ 'auto_detected' : 'databaseConf模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'databaseConf模块:2020年4月19日', /*简体*/ 'zh_TW' : 'databaseConf模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'databaseConf模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'databaseConf模块:2020年4月19日3' /*日语*/ }, 'class:localTool_2_181' : { /*要翻译的字符串*/ 'auto_detected' : 'externalApis模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'externalApis模块:2020年4月19日', /*简体*/ 'zh_TW' : 'externalApis模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'externalApis模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'externalApis模块:2020年4月19日3' /*日语*/ }, 'class:localTool_2_182' : { /*要翻译的字符串*/ 'auto_detected' : 'steamApis模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'steamApis模块:2020年4月19日', /*简体*/ 'zh_TW' : 'steamApis模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'steamApis模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'steamApis模块:2020年4月19日3' /*日语*/ }, 'class:localTool_2_183' : { /*要翻译的字符串*/ 'auto_detected' : 'translateApis模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'translateApis模块:2020年4月19日', /*简体*/ 'zh_TW' : 'translateApis模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'translateApis模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'translateApis模块:2020年4月19日3' /*日语*/ }, 'class:localTool_2_184' : { /*要翻译的字符串*/ 'auto_detected' : 'Utility模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'Utility模块:2020年4月19日', /*简体*/ 'zh_TW' : 'Utility模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'Utility模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'Utility模块:2020年4月19日3' /*日语*/ }, 'class:localTool_2_185' : { /*要翻译的字符串*/ 'auto_detected' : 'UI模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'UI模块:2020年4月19日', /*简体*/ 'zh_TW' : 'UI模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'UI模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'UI模块:2020年4月19日3' /*日语*/ }, 'class:localTool_2_186' : { /*要翻译的字符串*/ 'auto_detected' : 'Event模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'Event模块:2020年4月19日', /*简体*/ 'zh_TW' : 'Event模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'Event模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'Event模块:2020年4月19日3' /*日语*/ }, 'class:localTool_2_187' : { /*要翻译的字符串*/ 'auto_detected' : 'CityList模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'CityList模块:2020年4月19日', /*简体*/ 'zh_TW' : 'CityList模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'CityList模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'CityList模块:2020年4月19日3' /*日语*/ }, 'class:localTool_2_188' : { /*要翻译的字符串*/ 'auto_detected' : '联系作者:', /*自动检测*/ 'zh_CN' : '联系作者:', /*简体*/ 'zh_TW' : '联系作者:1', /*繁体*/ 'en_GB' : '联系作者:2', /*英语*/ 'jp_JP' : '联系作者:3' /*日语*/ }, 'class:localTool_2_189' : { /*要翻译的字符串*/ 'auto_detected' : '反馈错误', /*自动检测*/ 'zh_CN' : '反馈错误', /*简体*/ 'zh_TW' : '反馈错误1', /*繁体*/ 'en_GB' : '反馈错误2', /*英语*/ 'jp_JP' : '反馈错误3' /*日语*/ }, } }; var languagesList_loadUI_Html = { 'defaultLanguage' : 'auto_detected', /* (optional) although must be defined if you don't want en_GB */ 'showFlag': false, /* (optional) show/hide the flag 显示/隐藏旗帜 */ 'showCountry': false, /* (optional) show/hide the country name 显示/隐藏国家名称 */ 'showLanguage': true, /* (optional) show/hide the country language 显示/隐藏国家语言 */ 'labelTemplate': '{{language}}', 'languages' : { /* (optional) define **ADDITIONAL** custom languages 定义**额外的**自定义语言 */ 'auto_detected' : { 'country': 'Auto Detected', 'language' : 'Auto Detected', 'countryTranslated': 'Auto Detected', 'languageTranslated': 'Auto Detected', 'flag' : { 'url' : 'https://upload.wikimedia.org/wikipedia/commons/2/22/Flag_of_Hokkaido_Prefecture.svg', /* url of flag image 标志图像url */ 'class' : 'auto-flag' /* (optional) class to assign to the flag (e.g., for css styling) 类来分配给标志(例如,用于css样式) */ } } }, /* * Translate your strings below 翻译下面的字符串 */ 'strings' : { 'class:localTool_3_1' : { /*要翻译的字符串*/ 'auto_detected' : 'L', /*自动检测*/ 'zh_CN' : 'L', /*简体*/ 'zh_TW' : 'L1', /*繁体*/ 'en_GB' : 'L2', /*英语*/ 'jp_JP' : 'L3' /*日语*/ }, 'class:localTool_3_2' : { /*要翻译的字符串*/ 'auto_detected' : 'o', /*自动检测*/ 'zh_CN' : 'o', /*简体*/ 'zh_TW' : 'o1', /*繁体*/ 'en_GB' : 'o2', /*英语*/ 'jp_JP' : 'o3' /*日语*/ }, 'class:localTool_3_3' : { /*要翻译的字符串*/ 'auto_detected' : 'a', /*自动检测*/ 'zh_CN' : 'a', /*简体*/ 'zh_TW' : 'a1', /*繁体*/ 'en_GB' : 'a2', /*英语*/ 'jp_JP' : 'a3' /*日语*/ }, 'class:localTool_3_4' : { /*要翻译的字符串*/ 'auto_detected' : 'd', /*自动检测*/ 'zh_CN' : 'd', /*简体*/ 'zh_TW' : 'd1', /*繁体*/ 'en_GB' : 'd2', /*英语*/ 'jp_JP' : 'd3' /*日语*/ }, 'class:localTool_3_5' : { /*要翻译的字符串*/ 'auto_detected' : 'i', /*自动检测*/ 'zh_CN' : 'i', /*简体*/ 'zh_TW' : 'i1', /*繁体*/ 'en_GB' : 'i2', /*英语*/ 'jp_JP' : 'i3' /*日语*/ }, 'class:localTool_3_6' : { /*要翻译的字符串*/ 'auto_detected' : 'n', /*自动检测*/ 'zh_CN' : 'n', /*简体*/ 'zh_TW' : 'n1', /*繁体*/ 'en_GB' : 'n2', /*英语*/ 'jp_JP' : 'n3' /*日语*/ }, 'class:localTool_3_7' : { /*要翻译的字符串*/ 'auto_detected' : 'g', /*自动检测*/ 'zh_CN' : 'g', /*简体*/ 'zh_TW' : 'g1', /*繁体*/ 'en_GB' : 'g2', /*英语*/ 'jp_JP' : 'g3' /*日语*/ }, } }; var languagesList_mainUI_html = { 'defaultLanguage' : 'auto_detected', /* (optional) although must be defined if you don't want en_GB */ 'showFlag': false, /* (optional) show/hide the flag 显示/隐藏旗帜 */ 'showCountry': false, /* (optional) show/hide the country name 显示/隐藏国家名称 */ 'showLanguage': true, /* (optional) show/hide the country language 显示/隐藏国家语言 */ 'labelTemplate': '{{language}}', 'languages' : { /* (optional) define **ADDITIONAL** custom languages 定义**额外的**自定义语言 */ 'auto_detected' : { 'country': 'Auto Detected', 'language' : 'Auto Detected', 'countryTranslated': 'Auto Detected', 'languageTranslated': 'Auto Detected', 'flag' : { 'url' : 'https://upload.wikimedia.org/wikipedia/commons/2/22/Flag_of_Hokkaido_Prefecture.svg', /* url of flag image 标志图像url */ 'class' : 'auto-flag' /* (optional) class to assign to the flag (e.g., for css styling) 类来分配给标志(例如,用于css样式) */ } } }, /* * Translate your strings below 翻译下面的字符串 */ 'strings' : { 'class:localTool_4_1' : { /*要翻译的字符串*/ 'auto_detected' : '留言', /*自动检测*/ 'zh_CN' : '留言', /*简体*/ 'zh_TW' : '留言1', /*繁体*/ 'en_GB' : '留言2', /*英语*/ 'jp_JP' : '留言3' /*日语*/ }, 'class:localTool_4_2' : { /*要翻译的字符串*/ 'auto_detected' : '留言设置', /*自动检测*/ 'zh_CN' : '留言设置', /*简体*/ 'zh_TW' : '留言设置1', /*繁体*/ 'en_GB' : '留言设置2', /*英语*/ 'jp_JP' : '留言设置3' /*日语*/ }, 'class:localTool_4_3' : { /*要翻译的字符串*/ 'auto_detected' : '数据分析', /*自动检测*/ 'zh_CN' : '数据分析', /*简体*/ 'zh_TW' : '数据分析1', /*繁体*/ 'en_GB' : '数据分析2', /*英语*/ 'jp_JP' : '数据分析3' /*日语*/ }, 'class:localTool_4_4' : { /*要翻译的字符串*/ 'auto_detected' : '点赞助手', /*自动检测*/ 'zh_CN' : '点赞助手', /*简体*/ 'zh_TW' : '点赞助手1', /*繁体*/ 'en_GB' : '点赞助手2', /*英语*/ 'jp_JP' : '点赞助手3' /*日语*/ }, 'class:localTool_4_5' : { /*要翻译的字符串*/ 'auto_detected' : '拓展功能(测试)', /*自动检测*/ 'zh_CN' : '拓展功能(测试)', /*简体*/ 'zh_TW' : '拓展功能(测试)1', /*繁体*/ 'en_GB' : '拓展功能(测试)2', /*英语*/ 'jp_JP' : '拓展功能(测试)3' /*日语*/ }, 'class:localTool_4_6' : { /*要翻译的字符串*/ 'auto_detected' : '设置', /*自动检测*/ 'zh_CN' : '设置', /*简体*/ 'zh_TW' : '设置1', /*繁体*/ 'en_GB' : '设置2', /*英语*/ 'jp_JP' : '设置3' /*日语*/ }, 'class:localTool_4_7' : { /*要翻译的字符串*/ 'auto_detected' : '当前字符字节数:', /*自动检测*/ 'zh_CN' : '当前字符字节数:', /*简体*/ 'zh_TW' : '当前字符字节数:1', /*繁体*/ 'en_GB' : '当前字符字节数:2', /*英语*/ 'jp_JP' : '当前字符字节数:3' /*日语*/ }, 'class:localTool_4_8' : { /*要翻译的字符串*/ 'auto_detected' : '0', /*自动检测*/ 'zh_CN' : '0', /*简体*/ 'zh_TW' : '01', /*繁体*/ 'en_GB' : '02', /*英语*/ 'jp_JP' : '03' /*日语*/ }, 'class:localTool_4_9' : { /*要翻译的字符串*/ 'auto_detected' : '/999', /*自动检测*/ 'zh_CN' : '/999', /*简体*/ 'zh_TW' : '/9991', /*繁体*/ 'en_GB' : '/9992', /*英语*/ 'jp_JP' : '/9993' /*日语*/ }, 'class:localTool_4_10' : { /*要翻译的字符串*/ 'auto_detected' : '文本格式(直接添加或选择文字添加)', /*自动检测*/ 'zh_CN' : '文本格式(直接添加或选择文字添加)', /*简体*/ 'zh_TW' : '文本格式(直接添加或选择文字添加)1', /*繁体*/ 'en_GB' : '文本格式(直接添加或选择文字添加)2', /*英语*/ 'jp_JP' : '文本格式(直接添加或选择文字添加)3' /*日语*/ }, 'class:localTool_4_11' : { /*要翻译的字符串*/ 'auto_detected' : '直接选择或搜索选择', /*自动检测*/ 'zh_CN' : '直接选择或搜索选择', /*简体*/ 'zh_TW' : '直接选择或搜索选择1', /*繁体*/ 'en_GB' : '直接选择或搜索选择2', /*英语*/ 'jp_JP' : '直接选择或搜索选择3' /*日语*/ }, 'class:localTool_4_12' : { /*要翻译的字符串*/ 'auto_detected' : '[h1]标题文字[/h1]', /*自动检测*/ 'zh_CN' : '[h1]标题文字[/h1]', /*简体*/ 'zh_TW' : '[h1]标题文字[/h1]1', /*繁体*/ 'en_GB' : '[h1]标题文字[/h1]2', /*英语*/ 'jp_JP' : '[h1]标题文字[/h1]3' /*日语*/ }, 'class:localTool_4_13' : { /*要翻译的字符串*/ 'auto_detected' : '[b]粗体文本[/b]', /*自动检测*/ 'zh_CN' : '[b]粗体文本[/b]', /*简体*/ 'zh_TW' : '[b]粗体文本[/b]1', /*繁体*/ 'en_GB' : '[b]粗体文本[/b]2', /*英语*/ 'jp_JP' : '[b]粗体文本[/b]3' /*日语*/ }, 'class:localTool_4_14' : { /*要翻译的字符串*/ 'auto_detected' : '[u]下划线文本[/u]', /*自动检测*/ 'zh_CN' : '[u]下划线文本[/u]', /*简体*/ 'zh_TW' : '[u]下划线文本[/u]1', /*繁体*/ 'en_GB' : '[u]下划线文本[/u]2', /*英语*/ 'jp_JP' : '[u]下划线文本[/u]3' /*日语*/ }, 'class:localTool_4_15' : { /*要翻译的字符串*/ 'auto_detected' : '[i]斜体文本[/i]', /*自动检测*/ 'zh_CN' : '[i]斜体文本[/i]', /*简体*/ 'zh_TW' : '[i]斜体文本[/i]1', /*繁体*/ 'en_GB' : '[i]斜体文本[/i]2', /*英语*/ 'jp_JP' : '[i]斜体文本[/i]3' /*日语*/ }, 'class:localTool_4_16' : { /*要翻译的字符串*/ 'auto_detected' : '[strike]删除文本[/strike]', /*自动检测*/ 'zh_CN' : '[strike]删除文本[/strike]', /*简体*/ 'zh_TW' : '[strike]删除文本[/strike]1', /*繁体*/ 'en_GB' : '[strike]删除文本[/strike]2', /*英语*/ 'jp_JP' : '[strike]删除文本[/strike]3' /*日语*/ }, 'class:localTool_4_17' : { /*要翻译的字符串*/ 'auto_detected' : '[spoiler]隐藏文本[/spoiler]', /*自动检测*/ 'zh_CN' : '[spoiler]隐藏文本[/spoiler]', /*简体*/ 'zh_TW' : '[spoiler]隐藏文本[/spoiler]1', /*繁体*/ 'en_GB' : '[spoiler]隐藏文本[/spoiler]2', /*英语*/ 'jp_JP' : '[spoiler]隐藏文本[/spoiler]3' /*日语*/ }, 'class:localTool_4_18' : { /*要翻译的字符串*/ 'auto_detected' : '[noparse]不解析[b]标签[/b][/noparse]', /*自动检测*/ 'zh_CN' : '[noparse]不解析[b]标签[/b][/noparse]', /*简体*/ 'zh_TW' : '[noparse]不解析[b]标签[/b][/noparse]1', /*繁体*/ 'en_GB' : '[noparse]不解析[b]标签[/b][/noparse]2', /*英语*/ 'jp_JP' : '[noparse]不解析[b]标签[/b][/noparse]3' /*日语*/ }, 'class:localTool_4_19' : { /*要翻译的字符串*/ 'auto_detected' : '[url=store.steampowered.com]网站链接[/url]', /*自动检测*/ 'zh_CN' : '[url=store.steampowered.com]网站链接[/url]', /*简体*/ 'zh_TW' : '[url=store.steampowered.com]网站链接[/url]1', /*繁体*/ 'en_GB' : '[url=store.steampowered.com]网站链接[/url]2', /*英语*/ 'jp_JP' : '[url=store.steampowered.com]网站链接[/url]3' /*日语*/ }, 'class:localTool_4_20' : { /*要翻译的字符串*/ 'auto_detected' : '添加', /*自动检测*/ 'zh_CN' : '添加', /*简体*/ 'zh_TW' : '添加1', /*繁体*/ 'en_GB' : '添加2', /*英语*/ 'jp_JP' : '添加3' /*日语*/ }, 'class:localTool_4_21' : { /*要翻译的字符串*/ 'auto_detected' : '翻译模块(需要提前设置国籍):', /*自动检测*/ 'zh_CN' : '翻译模块(需要提前设置国籍):', /*简体*/ 'zh_TW' : '翻译模块(需要提前设置国籍):1', /*繁体*/ 'en_GB' : '翻译模块(需要提前设置国籍):2', /*英语*/ 'jp_JP' : '翻译模块(需要提前设置国籍):3' /*日语*/ }, 'class:localTool_4_22' : { /*要翻译的字符串*/ 'auto_detected' : '当前语言:', /*自动检测*/ 'zh_CN' : '当前语言:', /*简体*/ 'zh_TW' : '当前语言:1', /*繁体*/ 'en_GB' : '当前语言:2', /*英语*/ 'jp_JP' : '当前语言:3' /*日语*/ }, 'class:localTool_4_23' : { /*要翻译的字符串*/ 'auto_detected' : '自动检测', /*自动检测*/ 'zh_CN' : '自动检测', /*简体*/ 'zh_TW' : '自动检测1', /*繁体*/ 'en_GB' : '自动检测2', /*英语*/ 'jp_JP' : '自动检测3' /*日语*/ }, 'class:localTool_4_24' : { /*要翻译的字符串*/ 'auto_detected' : '中文简体', /*自动检测*/ 'zh_CN' : '中文简体', /*简体*/ 'zh_TW' : '中文简体1', /*繁体*/ 'en_GB' : '中文简体2', /*英语*/ 'jp_JP' : '中文简体3' /*日语*/ }, 'class:localTool_4_25' : { /*要翻译的字符串*/ 'auto_detected' : '英语', /*自动检测*/ 'zh_CN' : '英语', /*简体*/ 'zh_TW' : '英语1', /*繁体*/ 'en_GB' : '英语2', /*英语*/ 'jp_JP' : '英语3' /*日语*/ }, 'class:localTool_4_26' : { /*要翻译的字符串*/ 'auto_detected' : '日语', /*自动检测*/ 'zh_CN' : '日语', /*简体*/ 'zh_TW' : '日语1', /*繁体*/ 'en_GB' : '日语2', /*英语*/ 'jp_JP' : '日语3' /*日语*/ }, 'class:localTool_4_27' : { /*要翻译的字符串*/ 'auto_detected' : '目标语言:', /*自动检测*/ 'zh_CN' : '目标语言:', /*简体*/ 'zh_TW' : '目标语言:1', /*繁体*/ 'en_GB' : '目标语言:2', /*英语*/ 'jp_JP' : '目标语言:3' /*日语*/ }, 'class:localTool_4_28' : { /*要翻译的字符串*/ 'auto_detected' : '英语', /*自动检测*/ 'zh_CN' : '英语', /*简体*/ 'zh_TW' : '英语1', /*繁体*/ 'en_GB' : '英语2', /*英语*/ 'jp_JP' : '英语3' /*日语*/ }, 'class:localTool_4_29' : { /*要翻译的字符串*/ 'auto_detected' : '日语', /*自动检测*/ 'zh_CN' : '日语', /*简体*/ 'zh_TW' : '日语1', /*繁体*/ 'en_GB' : '日语2', /*英语*/ 'jp_JP' : '日语3' /*日语*/ }, 'class:localTool_4_30' : { /*要翻译的字符串*/ 'auto_detected' : '中文简体', /*自动检测*/ 'zh_CN' : '中文简体', /*简体*/ 'zh_TW' : '中文简体1', /*繁体*/ 'en_GB' : '中文简体2', /*英语*/ 'jp_JP' : '中文简体3' /*日语*/ }, 'class:localTool_4_31' : { /*要翻译的字符串*/ 'auto_detected' : '马新简体[zh-sg]', /*自动检测*/ 'zh_CN' : '马新简体[zh-sg]', /*简体*/ 'zh_TW' : '马新简体[zh-sg]1', /*繁体*/ 'en_GB' : '马新简体[zh-sg]2', /*英语*/ 'jp_JP' : '马新简体[zh-sg]3' /*日语*/ }, 'class:localTool_4_32' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文[zh-hant]', /*自动检测*/ 'zh_CN' : '繁體中文[zh-hant]', /*简体*/ 'zh_TW' : '繁體中文[zh-hant]1', /*繁体*/ 'en_GB' : '繁體中文[zh-hant]2', /*英语*/ 'jp_JP' : '繁體中文[zh-hant]3' /*日语*/ }, 'class:localTool_4_33' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文(香港)[zh-hk]', /*自动检测*/ 'zh_CN' : '繁體中文(香港)[zh-hk]', /*简体*/ 'zh_TW' : '繁體中文(香港)[zh-hk]1', /*繁体*/ 'en_GB' : '繁體中文(香港)[zh-hk]2', /*英语*/ 'jp_JP' : '繁體中文(香港)[zh-hk]3' /*日语*/ }, 'class:localTool_4_34' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文(澳门)[zh-mo]', /*自动检测*/ 'zh_CN' : '繁體中文(澳门)[zh-mo]', /*简体*/ 'zh_TW' : '繁體中文(澳门)[zh-mo]1', /*繁体*/ 'en_GB' : '繁體中文(澳门)[zh-mo]2', /*英语*/ 'jp_JP' : '繁體中文(澳门)[zh-mo]3' /*日语*/ }, 'class:localTool_4_35' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文(台湾)[zh-tw]', /*自动检测*/ 'zh_CN' : '繁體中文(台湾)[zh-tw]', /*简体*/ 'zh_TW' : '繁體中文(台湾)[zh-tw]1', /*繁体*/ 'en_GB' : '繁體中文(台湾)[zh-tw]2', /*英语*/ 'jp_JP' : '繁體中文(台湾)[zh-tw]3' /*日语*/ }, 'class:localTool_4_36' : { /*要翻译的字符串*/ 'auto_detected' : '翻译', /*自动检测*/ 'zh_CN' : '翻译', /*简体*/ 'zh_TW' : '翻译1', /*繁体*/ 'en_GB' : '翻译2', /*英语*/ 'jp_JP' : '翻译3' /*日语*/ }, 'class:localTool_4_37' : { /*要翻译的字符串*/ 'auto_detected' : '添加称呼模块(需要提前设置备注):', /*自动检测*/ 'zh_CN' : '添加称呼模块(需要提前设置备注):', /*简体*/ 'zh_TW' : '添加称呼模块(需要提前设置备注):1', /*繁体*/ 'en_GB' : '添加称呼模块(需要提前设置备注):2', /*英语*/ 'jp_JP' : '添加称呼模块(需要提前设置备注):3' /*日语*/ }, 'class:localTool_4_38' : { /*要翻译的字符串*/ 'auto_detected' : '自定义称呼模式', /*自动检测*/ 'zh_CN' : '自定义称呼模式', /*简体*/ 'zh_TW' : '自定义称呼模式1', /*繁体*/ 'en_GB' : '自定义称呼模式2', /*英语*/ 'jp_JP' : '自定义称呼模式3' /*日语*/ }, 'class:localTool_4_39' : { /*要翻译的字符串*/ 'auto_detected' : '在留言框添加自定义称呼标识符', /*自动检测*/ 'zh_CN' : '在留言框添加自定义称呼标识符', /*简体*/ 'zh_TW' : '在留言框添加自定义称呼标识符1', /*繁体*/ 'en_GB' : '在留言框添加自定义称呼标识符2', /*英语*/ 'jp_JP' : '在留言框添加自定义称呼标识符3' /*日语*/ }, 'class:localTool_4_40' : { /*要翻译的字符串*/ 'auto_detected' : '是否为好友添加称呼(如果好友没有备注则使用steam名称)', /*自动检测*/ 'zh_CN' : '是否为好友添加称呼(如果好友没有备注则使用steam名称)', /*简体*/ 'zh_TW' : '是否为好友添加称呼(如果好友没有备注则使用steam名称)1', /*繁体*/ 'en_GB' : '是否为好友添加称呼(如果好友没有备注则使用steam名称)2', /*英语*/ 'jp_JP' : '是否为好友添加称呼(如果好友没有备注则使用steam名称)3' /*日语*/ }, 'class:localTool_4_41' : { /*要翻译的字符串*/ 'auto_detected' : '是否为好友添加称呼(如果好友设置有备注则使用,否则不添加称呼)', /*自动检测*/ }, 'class:localTool_4_42' : { /*要翻译的字符串*/ 'auto_detected' : '格式化帮助', /*自动检测*/ 'zh_CN' : '格式化帮助', /*简体*/ 'zh_TW' : '格式化帮助1', /*繁体*/ 'en_GB' : '格式化帮助2', /*英语*/ 'jp_JP' : '格式化帮助3' /*日语*/ }, 'class:localTool_4_43' : { /*要翻译的字符串*/ 'auto_detected' : '发送评论给选择的好友', /*自动检测*/ 'zh_CN' : '发送评论给选择的好友', /*简体*/ 'zh_TW' : '发送评论给选择的好友1', /*繁体*/ 'en_GB' : '发送评论给选择的好友2', /*英语*/ 'jp_JP' : '发送评论给选择的好友3' /*日语*/ }, 'class:localTool_4_44' : { /*要翻译的字符串*/ 'auto_detected' : '根据国籍发送评论给选择的好友', /*自动检测*/ 'zh_CN' : '根据国籍发送评论给选择的好友', /*简体*/ 'zh_TW' : '根据国籍发送评论给选择的好友1', /*繁体*/ 'en_GB' : '根据国籍发送评论给选择的好友2', /*英语*/ 'jp_JP' : '根据国籍发送评论给选择的好友3' /*日语*/ }, 'class:localTool_4_45' : { /*要翻译的字符串*/ 'auto_detected' : '设置国籍:', /*自动检测*/ 'zh_CN' : '设置国籍:', /*简体*/ 'zh_TW' : '设置国籍:1', /*繁体*/ 'en_GB' : '设置国籍:2', /*英语*/ 'jp_JP' : '设置国籍:3' /*日语*/ }, 'class:localTool_4_46' : { /*要翻译的字符串*/ 'auto_detected' : '请选择要设置的国籍:', /*自动检测*/ 'zh_CN' : '请选择要设置的国籍:', /*简体*/ 'zh_TW' : '请选择要设置的国籍:1', /*繁体*/ 'en_GB' : '请选择要设置的国籍:2', /*英语*/ 'jp_JP' : '请选择要设置的国籍:3' /*日语*/ }, 'class:localTool_4_47' : { /*要翻译的字符串*/ 'auto_detected' : '简体中文', /*自动检测*/ 'zh_CN' : '简体中文', /*简体*/ 'zh_TW' : '简体中文1', /*繁体*/ 'en_GB' : '简体中文2', /*英语*/ 'jp_JP' : '简体中文3' /*日语*/ }, 'class:localTool_4_48' : { /*要翻译的字符串*/ 'auto_detected' : '英语', /*自动检测*/ 'zh_CN' : '英语', /*简体*/ 'zh_TW' : '英语1', /*繁体*/ 'en_GB' : '英语2', /*英语*/ 'jp_JP' : '英语3' /*日语*/ }, 'class:localTool_4_49' : { /*要翻译的字符串*/ 'auto_detected' : '日语', /*自动检测*/ 'zh_CN' : '日语', /*简体*/ 'zh_TW' : '日语1', /*繁体*/ 'en_GB' : '日语2', /*英语*/ 'jp_JP' : '日语3' /*日语*/ }, 'class:localTool_4_50' : { /*要翻译的字符串*/ 'auto_detected' : '马新简体(马来西亚,新加坡)[zh-sg]', /*自动检测*/ 'zh_CN' : '马新简体(马来西亚,新加坡)[zh-sg]', /*简体*/ 'zh_TW' : '马新简体(马来西亚,新加坡)[zh-sg]1', /*繁体*/ 'en_GB' : '马新简体(马来西亚,新加坡)[zh-sg]2', /*英语*/ 'jp_JP' : '马新简体(马来西亚,新加坡)[zh-sg]3' /*日语*/ }, 'class:localTool_4_51' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文[zh-hant]', /*自动检测*/ 'zh_CN' : '繁體中文[zh-hant]', /*简体*/ 'zh_TW' : '繁體中文[zh-hant]1', /*繁体*/ 'en_GB' : '繁體中文[zh-hant]2', /*英语*/ 'jp_JP' : '繁體中文[zh-hant]3' /*日语*/ }, 'class:localTool_4_52' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文(香港)[zh-hk]', /*自动检测*/ 'zh_CN' : '繁體中文(香港)[zh-hk]', /*简体*/ 'zh_TW' : '繁體中文(香港)[zh-hk]1', /*繁体*/ 'en_GB' : '繁體中文(香港)[zh-hk]2', /*英语*/ 'jp_JP' : '繁體中文(香港)[zh-hk]3' /*日语*/ }, 'class:localTool_4_53' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文(澳门)[zh-mo]', /*自动检测*/ 'zh_CN' : '繁體中文(澳门)[zh-mo]', /*简体*/ 'zh_TW' : '繁體中文(澳门)[zh-mo]1', /*繁体*/ 'en_GB' : '繁體中文(澳门)[zh-mo]2', /*英语*/ 'jp_JP' : '繁體中文(澳门)[zh-mo]3' /*日语*/ }, 'class:localTool_4_54' : { /*要翻译的字符串*/ 'auto_detected' : '繁體中文(台湾)[zh-tw]', /*自动检测*/ 'zh_CN' : '繁體中文(台湾)[zh-tw]', /*简体*/ 'zh_TW' : '繁體中文(台湾)[zh-tw]1', /*繁体*/ 'en_GB' : '繁體中文(台湾)[zh-tw]2', /*英语*/ 'jp_JP' : '繁體中文(台湾)[zh-tw]3' /*日语*/ }, 'class:localTool_4_55' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友设置国籍标识', /*自动检测*/ 'zh_CN' : '为选择的好友设置国籍标识', /*简体*/ 'zh_TW' : '为选择的好友设置国籍标识1', /*繁体*/ 'en_GB' : '为选择的好友设置国籍标识2', /*英语*/ 'jp_JP' : '为选择的好友设置国籍标识3' /*日语*/ }, 'class:localTool_4_56' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友取消国籍标识', /*自动检测*/ 'zh_CN' : '为选择的好友取消国籍标识', /*简体*/ 'zh_TW' : '为选择的好友取消国籍标识1', /*繁体*/ 'en_GB' : '为选择的好友取消国籍标识2', /*英语*/ 'jp_JP' : '为选择的好友取消国籍标识3' /*日语*/ }, 'class:localTool_4_57' : { /*要翻译的字符串*/ 'auto_detected' : '设置不留言:', /*自动检测*/ 'zh_CN' : '设置不留言:', /*简体*/ 'zh_TW' : '设置不留言:1', /*繁体*/ 'en_GB' : '设置不留言:2', /*英语*/ 'jp_JP' : '设置不留言:3' /*日语*/ }, 'class:localTool_4_58' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友设置不留言', /*自动检测*/ 'zh_CN' : '为选择的好友设置不留言', /*简体*/ 'zh_TW' : '为选择的好友设置不留言1', /*繁体*/ 'en_GB' : '为选择的好友设置不留言2', /*英语*/ 'jp_JP' : '为选择的好友设置不留言3' /*日语*/ }, 'class:localTool_4_59' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友取消设置不留言', /*自动检测*/ 'zh_CN' : '为选择的好友取消设置不留言', /*简体*/ 'zh_TW' : '为选择的好友取消设置不留言1', /*繁体*/ 'en_GB' : '为选择的好友取消设置不留言2', /*英语*/ 'jp_JP' : '为选择的好友取消设置不留言3' /*日语*/ }, 'class:localTool_4_60' : { /*要翻译的字符串*/ 'auto_detected' : '设置留言时间间隔:', /*自动检测*/ 'zh_CN' : '设置留言时间间隔:', /*简体*/ 'zh_TW' : '设置留言时间间隔:1', /*繁体*/ 'en_GB' : '设置留言时间间隔:2', /*英语*/ 'jp_JP' : '设置留言时间间隔:3' /*日语*/ }, 'class:localTool_4_61' : { /*要翻译的字符串*/ }, 'class:localTool_4_62' : { /*要翻译的字符串*/ }, 'class:localTool_4_63' : { /*要翻译的字符串*/ 'auto_detected' : '请选择留言', /*自动检测*/ 'zh_CN' : '请选择留言', /*简体*/ 'zh_TW' : '请选择留言1', /*繁体*/ 'en_GB' : '请选择留言2', /*英语*/ 'jp_JP' : '请选择留言3' /*日语*/ }, 'class:localTool_4_64' : { /*要翻译的字符串*/ 'auto_detected' : '留言日期差', /*自动检测*/ 'zh_CN' : '留言日期差', /*简体*/ 'zh_TW' : '留言日期差1', /*繁体*/ 'en_GB' : '留言日期差2', /*英语*/ 'jp_JP' : '留言日期差3' /*日语*/ }, 'class:localTool_4_65' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友设置留言时间间隔', /*自动检测*/ 'zh_CN' : '为选择的好友设置留言时间间隔', /*简体*/ 'zh_TW' : '为选择的好友设置留言时间间隔1', /*繁体*/ 'en_GB' : '为选择的好友设置留言时间间隔2', /*英语*/ 'jp_JP' : '为选择的好友设置留言时间间隔3' /*日语*/ }, 'class:localTool_4_66' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友取消设置留言时间间隔', /*自动检测*/ 'zh_CN' : '为选择的好友取消设置留言时间间隔', /*简体*/ 'zh_TW' : '为选择的好友取消设置留言时间间隔1', /*繁体*/ 'en_GB' : '为选择的好友取消设置留言时间间隔2', /*英语*/ 'jp_JP' : '为选择的好友取消设置留言时间间隔3' /*日语*/ }, 'class:localTool_4_67' : { /*要翻译的字符串*/ 'auto_detected' : '设置自动留言计划:', /*自动检测*/ 'zh_CN' : '设置自动留言计划:', /*简体*/ 'zh_TW' : '设置自动留言计划:1', /*繁体*/ 'en_GB' : '设置自动留言计划:2', /*英语*/ 'jp_JP' : '设置自动留言计划:3' /*日语*/ }, 'class:localTool_4_68' : { /*要翻译的字符串*/ 'auto_detected' : '请选择时间', /*自动检测*/ 'zh_CN' : '请选择时间', /*简体*/ 'zh_TW' : '请选择时间1', /*繁体*/ 'en_GB' : '请选择时间2', /*英语*/ 'jp_JP' : '请选择时间3' /*日语*/ }, 'class:localTool_4_69' : { /*要翻译的字符串*/ 'auto_detected' : '请选择时间', /*自动检测*/ 'zh_CN' : '请选择时间', /*简体*/ 'zh_TW' : '请选择时间1', /*繁体*/ 'en_GB' : '请选择时间2', /*英语*/ 'jp_JP' : '请选择时间3' /*日语*/ }, 'class:localTool_4_70' : { /*要翻译的字符串*/ 'auto_detected' : '设置好友分组:', /*自动检测*/ 'zh_CN' : '设置好友分组:', /*简体*/ 'zh_TW' : '设置好友分组:1', /*繁体*/ 'en_GB' : '设置好友分组:2', /*英语*/ 'jp_JP' : '设置好友分组:3' /*日语*/ }, 'class:localTool_4_71' : { /*要翻译的字符串*/ 'auto_detected' : '分组列表', /*自动检测*/ 'zh_CN' : '分组列表', /*简体*/ 'zh_TW' : '分组列表1', /*繁体*/ 'en_GB' : '分组列表2', /*英语*/ 'jp_JP' : '分组列表3' /*日语*/ }, 'class:localTool_4_72' : { /*要翻译的字符串*/ 'auto_detected' : '直接选择或搜索选择', /*自动检测*/ 'zh_CN' : '直接选择或搜索选择', /*简体*/ 'zh_TW' : '直接选择或搜索选择1', /*繁体*/ 'en_GB' : '直接选择或搜索选择2', /*英语*/ 'jp_JP' : '直接选择或搜索选择3' /*日语*/ }, 'class:localTool_4_73' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_4_74' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_4_75' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_4_76' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_4_77' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_4_78' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_4_79' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_4_80' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_4_81' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_4_82' : { /*要翻译的字符串*/ 'auto_detected' : '编辑列表', /*自动检测*/ 'zh_CN' : '编辑列表', /*简体*/ 'zh_TW' : '编辑列表1', /*繁体*/ 'en_GB' : '编辑列表2', /*英语*/ 'jp_JP' : '编辑列表3' /*日语*/ }, 'class:localTool_4_83' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友添加分组', /*自动检测*/ 'zh_CN' : '为选择的好友添加分组', /*简体*/ 'zh_TW' : '为选择的好友添加分组1', /*繁体*/ 'en_GB' : '为选择的好友添加分组2', /*英语*/ 'jp_JP' : '为选择的好友添加分组3' /*日语*/ }, 'class:localTool_4_84' : { /*要翻译的字符串*/ 'auto_detected' : '为选择的好友取消添加分组', /*自动检测*/ 'zh_CN' : '为选择的好友取消添加分组', /*简体*/ 'zh_TW' : '为选择的好友取消添加分组1', /*繁体*/ 'en_GB' : '为选择的好友取消添加分组2', /*英语*/ 'jp_JP' : '为选择的好友取消添加分组3' /*日语*/ }, 'class:localTool_4_85' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_4_86' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_4_87' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_4_88' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_4_89' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_4_90' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_4_91' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_4_92' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_4_93' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_4_94' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_4_95' : { /*要翻译的字符串*/ 'auto_detected' : '分组名称', /*自动检测*/ 'zh_CN' : '分组名称', /*简体*/ 'zh_TW' : '分组名称1', /*繁体*/ 'en_GB' : '分组名称2', /*英语*/ 'jp_JP' : '分组名称3' /*日语*/ }, 'class:localTool_4_96' : { /*要翻译的字符串*/ 'auto_detected' : '用户', /*自动检测*/ 'zh_CN' : '用户', /*简体*/ 'zh_TW' : '用户1', /*繁体*/ 'en_GB' : '用户2', /*英语*/ 'jp_JP' : '用户3' /*日语*/ }, 'class:localTool_4_97' : { /*要翻译的字符串*/ 'auto_detected' : '按国籍进行高亮分组', /*自动检测*/ 'zh_CN' : '按国籍进行高亮分组', /*简体*/ 'zh_TW' : '按国籍进行高亮分组1', /*繁体*/ 'en_GB' : '按国籍进行高亮分组2', /*英语*/ 'jp_JP' : '按国籍进行高亮分组3' /*日语*/ }, 'class:localTool_4_98' : { /*要翻译的字符串*/ 'auto_detected' : '按国籍进行排序分组(慢)', /*自动检测*/ 'zh_CN' : '按国籍进行排序分组(慢)', /*简体*/ 'zh_TW' : '按国籍进行排序分组(慢)1', /*繁体*/ 'en_GB' : '按国籍进行排序分组(慢)2', /*英语*/ 'jp_JP' : '按国籍进行排序分组(慢)3' /*日语*/ }, 'class:localTool_4_99' : { /*要翻译的字符串*/ 'auto_detected' : '按在线时间进行排序分组', /*自动检测*/ 'zh_CN' : '按在线时间进行排序分组', /*简体*/ 'zh_TW' : '按在线时间进行排序分组1', /*繁体*/ 'en_GB' : '按在线时间进行排序分组2', /*英语*/ 'jp_JP' : '按在线时间进行排序分组3' /*日语*/ }, 'class:localTool_4_100' : { /*要翻译的字符串*/ 'auto_detected' : '显示好友详细数据-不可用', /*自动检测*/ 'zh_CN' : '显示好友详细数据-不可用', /*简体*/ 'zh_TW' : '显示好友详细数据-不可用1', /*繁体*/ 'en_GB' : '显示好友详细数据-不可用2', /*英语*/ 'jp_JP' : '显示好友详细数据-不可用3' /*日语*/ }, 'class:localTool_4_101' : { /*要翻译的字符串*/ 'auto_detected' : '好友数据统计', /*自动检测*/ 'zh_CN' : '好友数据统计', /*简体*/ 'zh_TW' : '好友数据统计1', /*繁体*/ 'en_GB' : '好友数据统计2', /*英语*/ 'jp_JP' : '好友数据统计3' /*日语*/ }, 'class:localTool_4_102' : { /*要翻译的字符串*/ 'auto_detected' : '留言数据统计', /*自动检测*/ 'zh_CN' : '留言数据统计', /*简体*/ 'zh_TW' : '留言数据统计1', /*繁体*/ 'en_GB' : '留言数据统计2', /*英语*/ 'jp_JP' : '留言数据统计3' /*日语*/ }, 'class:localTool_4_103' : { /*要翻译的字符串*/ 'auto_detected' : '关系网统计', /*自动检测*/ 'zh_CN' : '关系网统计', /*简体*/ 'zh_TW' : '关系网统计1', /*繁体*/ 'en_GB' : '关系网统计2', /*英语*/ 'jp_JP' : '关系网统计3' /*日语*/ }, 'class:localTool_4_104' : { /*要翻译的字符串*/ 'auto_detected' : '当前配置统计', /*自动检测*/ 'zh_CN' : '当前配置统计', /*简体*/ 'zh_TW' : '当前配置统计1', /*繁体*/ 'en_GB' : '当前配置统计2', /*英语*/ 'jp_JP' : '当前配置统计3' /*日语*/ }, 'class:localTool_4_105' : { /*要翻译的字符串*/ 'auto_detected' : '查看好友配置统计', /*自动检测*/ 'zh_CN' : '查看好友配置统计', /*简体*/ 'zh_TW' : '查看好友配置统计1', /*繁体*/ 'en_GB' : '查看好友配置统计2', /*英语*/ 'jp_JP' : '查看好友配置统计3' /*日语*/ }, 'class:localTool_4_106' : { /*要翻译的字符串*/ 'auto_detected' : '数据表格(汇总所有的数据:id,名称,备注,国籍(语言),等级,好友数量,游戏数量,dlc数量,创意工坊数量,艺术作品数量,动态数量)', /*自动检测*/ }, 'class:localTool_4_107' : { /*要翻译的字符串*/ 'auto_detected' : '分为:', /*自动检测*/ 'zh_CN' : '分为:', /*简体*/ 'zh_TW' : '分为:1', /*繁体*/ 'en_GB' : '分为:2', /*英语*/ 'jp_JP' : '分为:3' /*日语*/ }, 'class:localTool_4_108' : { /*要翻译的字符串*/ 'auto_detected' : '按国籍的饼图(总留言数量),', /*自动检测*/ 'zh_CN' : '按国籍的饼图(总留言数量),', /*简体*/ 'zh_TW' : '按国籍的饼图(总留言数量),1', /*繁体*/ 'en_GB' : '按国籍的饼图(总留言数量),2', /*英语*/ 'jp_JP' : '按国籍的饼图(总留言数量),3' /*日语*/ }, 'class:localTool_4_109' : { /*要翻译的字符串*/ 'auto_detected' : '按每天留言数据的折线图(统计所有的留言数据,生成的折线图),', /*自动检测*/ }, 'class:localTool_4_110' : { /*要翻译的字符串*/ }, 'class:localTool_4_111' : { /*要翻译的字符串*/ 'auto_detected' : '数据表格(汇总所有的数据)', /*自动检测*/ 'zh_CN' : '数据表格(汇总所有的数据)', /*简体*/ 'zh_TW' : '数据表格(汇总所有的数据)1', /*繁体*/ 'en_GB' : '数据表格(汇总所有的数据)2', /*英语*/ 'jp_JP' : '数据表格(汇总所有的数据)3' /*日语*/ }, 'class:localTool_4_112' : { /*要翻译的字符串*/ 'auto_detected' : '好友关系网(仅统计共同好友)', /*自动检测*/ 'zh_CN' : '好友关系网(仅统计共同好友)', /*简体*/ 'zh_TW' : '好友关系网(仅统计共同好友)1', /*繁体*/ 'en_GB' : '好友关系网(仅统计共同好友)2', /*英语*/ 'jp_JP' : '好友关系网(仅统计共同好友)3' /*日语*/ }, 'class:localTool_4_113' : { /*要翻译的字符串*/ 'auto_detected' : '当前的配置数据和运行状态', /*自动检测*/ 'zh_CN' : '当前的配置数据和运行状态', /*简体*/ 'zh_TW' : '当前的配置数据和运行状态1', /*繁体*/ 'en_GB' : '当前的配置数据和运行状态2', /*英语*/ 'jp_JP' : '当前的配置数据和运行状态3' /*日语*/ }, 'class:localTool_4_114' : { /*要翻译的字符串*/ 'auto_detected' : '对好友设置的配置数据(比如国籍,不留言,留言时间间隔等)', /*自动检测*/ 'zh_CN' : '对好友设置的配置数据(比如国籍,不留言,留言时间间隔等)', /*简体*/ 'zh_TW' : '对好友设置的配置数据(比如国籍,不留言,留言时间间隔等)1', /*繁体*/ 'en_GB' : '对好友设置的配置数据(比如国籍,不留言,留言时间间隔等)2', /*英语*/ 'jp_JP' : '对好友设置的配置数据(比如国籍,不留言,留言时间间隔等)3' /*日语*/ }, 'class:localTool_4_115' : { /*要翻译的字符串*/ 'auto_detected' : '动态点赞助手', /*自动检测*/ 'zh_CN' : '动态点赞助手', /*简体*/ 'zh_TW' : '动态点赞助手1', /*繁体*/ 'en_GB' : '动态点赞助手2', /*英语*/ 'jp_JP' : '动态点赞助手3' /*日语*/ }, 'class:localTool_4_116' : { /*要翻译的字符串*/ 'auto_detected' : '总开关', /*自动检测*/ 'zh_CN' : '总开关', /*简体*/ 'zh_TW' : '总开关1', /*繁体*/ 'en_GB' : '总开关2', /*英语*/ 'jp_JP' : '总开关3' /*日语*/ }, 'class:localTool_4_117' : { /*要翻译的字符串*/ 'auto_detected' : '设置点赞内容:', /*自动检测*/ 'zh_CN' : '设置点赞内容:', /*简体*/ 'zh_TW' : '设置点赞内容:1', /*繁体*/ 'en_GB' : '设置点赞内容:2', /*英语*/ 'jp_JP' : '设置点赞内容:3' /*日语*/ }, 'class:localTool_4_118' : { /*要翻译的字符串*/ 'auto_detected' : '点赞内容:', /*自动检测*/ 'zh_CN' : '点赞内容:', /*简体*/ 'zh_TW' : '点赞内容:1', /*繁体*/ 'en_GB' : '点赞内容:2', /*英语*/ 'jp_JP' : '点赞内容:3' /*日语*/ }, 'class:localTool_4_119' : { /*要翻译的字符串*/ 'auto_detected' : '设置自动点赞模式:', /*自动检测*/ 'zh_CN' : '设置自动点赞模式:', /*简体*/ 'zh_TW' : '设置自动点赞模式:1', /*繁体*/ 'en_GB' : '设置自动点赞模式:2', /*英语*/ 'jp_JP' : '设置自动点赞模式:3' /*日语*/ }, 'class:localTool_4_120' : { /*要翻译的字符串*/ 'auto_detected' : '点赞模式:', /*自动检测*/ 'zh_CN' : '点赞模式:', /*简体*/ 'zh_TW' : '点赞模式:1', /*繁体*/ 'en_GB' : '点赞模式:2', /*英语*/ 'jp_JP' : '点赞模式:3' /*日语*/ }, 'class:localTool_4_121' : { /*要翻译的字符串*/ 'auto_detected' : '设置自动点赞时间区间(默认今天~之前所有的动态内容)', /*自动检测*/ 'zh_CN' : '设置自动点赞时间区间(默认今天~之前所有的动态内容)', /*简体*/ 'zh_TW' : '设置自动点赞时间区间(默认今天~之前所有的动态内容)1', /*繁体*/ 'en_GB' : '设置自动点赞时间区间(默认今天~之前所有的动态内容)2', /*英语*/ 'jp_JP' : '设置自动点赞时间区间(默认今天~之前所有的动态内容)3' /*日语*/ }, 'class:localTool_4_122' : { /*要翻译的字符串*/ 'auto_detected' : '请选择范围', /*自动检测*/ 'zh_CN' : '请选择范围', /*简体*/ 'zh_TW' : '请选择范围1', /*繁体*/ 'en_GB' : '请选择范围2', /*英语*/ 'jp_JP' : '请选择范围3' /*日语*/ }, 'class:localTool_4_123' : { /*要翻译的字符串*/ 'auto_detected' : '点赞进度时间线', /*自动检测*/ 'zh_CN' : '点赞进度时间线', /*简体*/ 'zh_TW' : '点赞进度时间线1', /*繁体*/ 'en_GB' : '点赞进度时间线2', /*英语*/ 'jp_JP' : '点赞进度时间线3' /*日语*/ }, 'class:localTool_4_124' : { /*要翻译的字符串*/ 'auto_detected' : '', /*自动检测*/ 'zh_CN' : '', /*简体*/ 'zh_TW' : '1', /*繁体*/ 'en_GB' : '2', /*英语*/ 'jp_JP' : '3' /*日语*/ }, 'class:localTool_4_125' : { /*要翻译的字符串*/ 'auto_detected' : '8月18日', /*自动检测*/ 'zh_CN' : '8月18日', /*简体*/ 'zh_TW' : '8月18日1', /*繁体*/ 'en_GB' : '8月18日2', /*英语*/ 'jp_JP' : '8月18日3' /*日语*/ }, 'class:localTool_4_126' : { /*要翻译的字符串*/ 'auto_detected' : '已点赞状态x条,点赞发布艺术作品x条,点赞收藏艺术作品x条', /*自动检测*/ 'zh_CN' : '已点赞状态x条,点赞发布艺术作品x条,点赞收藏艺术作品x条', /*简体*/ 'zh_TW' : '已点赞状态x条,点赞发布艺术作品x条,点赞收藏艺术作品x条1', /*繁体*/ 'en_GB' : '已点赞状态x条,点赞发布艺术作品x条,点赞收藏艺术作品x条2', /*英语*/ 'jp_JP' : '已点赞状态x条,点赞发布艺术作品x条,点赞收藏艺术作品x条3' /*日语*/ }, 'class:localTool_4_127' : { /*要翻译的字符串*/ 'auto_detected' : '已点赞评测x条,点赞发布创意工坊x条,点赞收藏创意工坊x条', /*自动检测*/ 'zh_CN' : '已点赞评测x条,点赞发布创意工坊x条,点赞收藏创意工坊x条', /*简体*/ 'zh_TW' : '已点赞评测x条,点赞发布创意工坊x条,点赞收藏创意工坊x条1', /*繁体*/ 'en_GB' : '已点赞评测x条,点赞发布创意工坊x条,点赞收藏创意工坊x条2', /*英语*/ 'jp_JP' : '已点赞评测x条,点赞发布创意工坊x条,点赞收藏创意工坊x条3' /*日语*/ }, 'class:localTool_4_128' : { /*要翻译的字符串*/ 'auto_detected' : '已点赞购买状态x条,点赞发布指南x条,点赞收藏指南x条', /*自动检测*/ 'zh_CN' : '已点赞购买状态x条,点赞发布指南x条,点赞收藏指南x条', /*简体*/ 'zh_TW' : '已点赞购买状态x条,点赞发布指南x条,点赞收藏指南x条1', /*繁体*/ 'en_GB' : '已点赞购买状态x条,点赞发布指南x条,点赞收藏指南x条2', /*英语*/ 'jp_JP' : '已点赞购买状态x条,点赞发布指南x条,点赞收藏指南x条3' /*日语*/ }, 'class:localTool_4_129' : { /*要翻译的字符串*/ 'auto_detected' : '已点赞组通知x条,点赞上次载图x条,点赞收藏载图x条', /*自动检测*/ 'zh_CN' : '已点赞组通知x条,点赞上次载图x条,点赞收藏载图x条', /*简体*/ 'zh_TW' : '已点赞组通知x条,点赞上次载图x条,点赞收藏载图x条1', /*繁体*/ 'en_GB' : '已点赞组通知x条,点赞上次载图x条,点赞收藏载图x条2', /*英语*/ 'jp_JP' : '已点赞组通知x条,点赞上次载图x条,点赞收藏载图x条3' /*日语*/ }, 'class:localTool_4_130' : { /*要翻译的字符串*/ 'auto_detected' : '已点赞组活动x条,点赞上传视频x条,点赞收藏视频x条', /*自动检测*/ 'zh_CN' : '已点赞组活动x条,点赞上传视频x条,点赞收藏视频x条', /*简体*/ 'zh_TW' : '已点赞组活动x条,点赞上传视频x条,点赞收藏视频x条1', /*繁体*/ 'en_GB' : '已点赞组活动x条,点赞上传视频x条,点赞收藏视频x条2', /*英语*/ 'jp_JP' : '已点赞组活动x条,点赞上传视频x条,点赞收藏视频x条3' /*日语*/ }, 'class:localTool_4_131' : { /*要翻译的字符串*/ 'auto_detected' : '', /*自动检测*/ 'zh_CN' : '', /*简体*/ 'zh_TW' : '1', /*繁体*/ 'en_GB' : '2', /*英语*/ 'jp_JP' : '3' /*日语*/ }, 'class:localTool_4_132' : { /*要翻译的字符串*/ 'auto_detected' : '8月16日', /*自动检测*/ 'zh_CN' : '8月16日', /*简体*/ 'zh_TW' : '8月16日1', /*繁体*/ 'en_GB' : '8月16日2', /*英语*/ 'jp_JP' : '8月16日3' /*日语*/ }, 'class:localTool_4_133' : { /*要翻译的字符串*/ }, 'class:localTool_4_134' : { /*要翻译的字符串*/ 'auto_detected' : '《登高》', /*自动检测*/ 'zh_CN' : '《登高》', /*简体*/ 'zh_TW' : '《登高》1', /*繁体*/ 'en_GB' : '《登高》2', /*英语*/ 'jp_JP' : '《登高》3' /*日语*/ }, 'class:localTool_4_135' : { /*要翻译的字符串*/ 'auto_detected' : '《茅屋为秋风所破歌》', /*自动检测*/ 'zh_CN' : '《茅屋为秋风所破歌》', /*简体*/ 'zh_TW' : '《茅屋为秋风所破歌》1', /*繁体*/ 'en_GB' : '《茅屋为秋风所破歌》2', /*英语*/ 'jp_JP' : '《茅屋为秋风所破歌》3' /*日语*/ }, 'class:localTool_4_136' : { /*要翻译的字符串*/ 'auto_detected' : '', /*自动检测*/ 'zh_CN' : '', /*简体*/ 'zh_TW' : '1', /*繁体*/ 'en_GB' : '2', /*英语*/ 'jp_JP' : '3' /*日语*/ }, 'class:localTool_4_137' : { /*要翻译的字符串*/ 'auto_detected' : '8月15日', /*自动检测*/ 'zh_CN' : '8月15日', /*简体*/ 'zh_TW' : '8月15日1', /*繁体*/ 'en_GB' : '8月15日2', /*英语*/ 'jp_JP' : '8月15日3' /*日语*/ }, 'class:localTool_4_138' : { /*要翻译的字符串*/ 'auto_detected' : '中国人民抗日战争胜利日', /*自动检测*/ 'zh_CN' : '中国人民抗日战争胜利日', /*简体*/ 'zh_TW' : '中国人民抗日战争胜利日1', /*繁体*/ 'en_GB' : '中国人民抗日战争胜利日2', /*英语*/ 'jp_JP' : '中国人民抗日战争胜利日3' /*日语*/ }, 'class:localTool_4_139' : { /*要翻译的字符串*/ }, 'class:localTool_4_140' : { /*要翻译的字符串*/ 'auto_detected' : '铭记、感恩', /*自动检测*/ 'zh_CN' : '铭记、感恩', /*简体*/ 'zh_TW' : '铭记、感恩1', /*繁体*/ 'en_GB' : '铭记、感恩2', /*英语*/ 'jp_JP' : '铭记、感恩3' /*日语*/ }, 'class:localTool_4_141' : { /*要翻译的字符串*/ 'auto_detected' : '所有为中华民族浴血奋战的英雄将士', /*自动检测*/ 'zh_CN' : '所有为中华民族浴血奋战的英雄将士', /*简体*/ 'zh_TW' : '所有为中华民族浴血奋战的英雄将士1', /*繁体*/ 'en_GB' : '所有为中华民族浴血奋战的英雄将士2', /*英语*/ 'jp_JP' : '所有为中华民族浴血奋战的英雄将士3' /*日语*/ }, 'class:localTool_4_142' : { /*要翻译的字符串*/ 'auto_detected' : '永垂不朽', /*自动检测*/ 'zh_CN' : '永垂不朽', /*简体*/ 'zh_TW' : '永垂不朽1', /*繁体*/ 'en_GB' : '永垂不朽2', /*英语*/ 'jp_JP' : '永垂不朽3' /*日语*/ }, 'class:localTool_4_143' : { /*要翻译的字符串*/ 'auto_detected' : '', /*自动检测*/ 'zh_CN' : '', /*简体*/ 'zh_TW' : '1', /*繁体*/ 'en_GB' : '2', /*英语*/ 'jp_JP' : '3' /*日语*/ }, 'class:localTool_4_144' : { /*要翻译的字符串*/ 'auto_detected' : '过去', /*自动检测*/ 'zh_CN' : '过去', /*简体*/ 'zh_TW' : '过去1', /*繁体*/ 'en_GB' : '过去2', /*英语*/ 'jp_JP' : '过去3' /*日语*/ }, 'class:localTool_4_145' : { /*要翻译的字符串*/ 'auto_detected' : '喜加一助手', /*自动检测*/ 'zh_CN' : '喜加一助手', /*简体*/ 'zh_TW' : '喜加一助手1', /*繁体*/ 'en_GB' : '喜加一助手2', /*英语*/ 'jp_JP' : '喜加一助手3' /*日语*/ }, 'class:localTool_4_146' : { /*要翻译的字符串*/ 'auto_detected' : '总开关', /*自动检测*/ 'zh_CN' : '总开关', /*简体*/ 'zh_TW' : '总开关1', /*繁体*/ 'en_GB' : '总开关2', /*英语*/ 'jp_JP' : '总开关3' /*日语*/ }, 'class:localTool_4_147' : { /*要翻译的字符串*/ 'auto_detected' : '设置:', /*自动检测*/ 'zh_CN' : '设置:', /*简体*/ 'zh_TW' : '设置:1', /*繁体*/ 'en_GB' : '设置:2', /*英语*/ 'jp_JP' : '设置:3' /*日语*/ }, 'class:localTool_4_148' : { /*要翻译的字符串*/ 'auto_detected' : '设置喜加一数据来源', /*自动检测*/ 'zh_CN' : '设置喜加一数据来源', /*简体*/ 'zh_TW' : '设置喜加一数据来源1', /*繁体*/ 'en_GB' : '设置喜加一数据来源2', /*英语*/ 'jp_JP' : '设置喜加一数据来源3' /*日语*/ }, 'class:localTool_4_149' : { /*要翻译的字符串*/ 'auto_detected' : '设置:', /*自动检测*/ 'zh_CN' : '设置:', /*简体*/ 'zh_TW' : '设置:1', /*繁体*/ 'en_GB' : '设置:2', /*英语*/ 'jp_JP' : '设置:3' /*日语*/ }, 'class:localTool_4_150' : { /*要翻译的字符串*/ 'auto_detected' : '功能设置', /*自动检测*/ 'zh_CN' : '功能设置', /*简体*/ 'zh_TW' : '功能设置1', /*繁体*/ 'en_GB' : '功能设置2', /*英语*/ 'jp_JP' : '功能设置3' /*日语*/ }, 'class:localTool_4_151' : { /*要翻译的字符串*/ 'auto_detected' : 'Debug模式', /*自动检测*/ 'zh_CN' : 'Debug模式', /*简体*/ 'zh_TW' : 'Debug模式1', /*繁体*/ 'en_GB' : 'Debug模式2', /*英语*/ 'jp_JP' : 'Debug模式3' /*日语*/ }, 'class:localTool_4_152' : { /*要翻译的字符串*/ 'auto_detected' : '弹出层', /*自动检测*/ 'zh_CN' : '弹出层', /*简体*/ 'zh_TW' : '弹出层1', /*繁体*/ 'en_GB' : '弹出层2', /*英语*/ 'jp_JP' : '弹出层3' /*日语*/ }, 'class:localTool_4_153' : { /*要翻译的字符串*/ 'auto_detected' : '滑块', /*自动检测*/ 'zh_CN' : '滑块', /*简体*/ 'zh_TW' : '滑块1', /*繁体*/ 'en_GB' : '滑块2', /*英语*/ 'jp_JP' : '滑块3' /*日语*/ }, 'class:localTool_4_154' : { /*要翻译的字符串*/ 'auto_detected' : '导入导出重置当前设置', /*自动检测*/ 'zh_CN' : '导入导出重置当前设置', /*简体*/ 'zh_TW' : '导入导出重置当前设置1', /*繁体*/ 'en_GB' : '导入导出重置当前设置2', /*英语*/ 'jp_JP' : '导入导出重置当前设置3' /*日语*/ }, 'class:localTool_4_155' : { /*要翻译的字符串*/ 'auto_detected' : '弹出层', /*自动检测*/ 'zh_CN' : '弹出层', /*简体*/ 'zh_TW' : '弹出层1', /*繁体*/ 'en_GB' : '弹出层2', /*英语*/ 'jp_JP' : '弹出层3' /*日语*/ }, 'class:localTool_4_156' : { /*要翻译的字符串*/ 'auto_detected' : '', /*自动检测*/ 'zh_CN' : '', /*简体*/ 'zh_TW' : '1', /*繁体*/ 'en_GB' : '2', /*英语*/ 'jp_JP' : '3' /*日语*/ }, 'class:localTool_4_157' : { /*要翻译的字符串*/ 'auto_detected' : '点击上传,或将文件拖拽到此处', /*自动检测*/ 'zh_CN' : '点击上传,或将文件拖拽到此处', /*简体*/ 'zh_TW' : '点击上传,或将文件拖拽到此处1', /*繁体*/ 'en_GB' : '点击上传,或将文件拖拽到此处2', /*英语*/ 'jp_JP' : '点击上传,或将文件拖拽到此处3' /*日语*/ }, 'class:localTool_4_158' : { /*要翻译的字符串*/ 'auto_detected' : '界面设置', /*自动检测*/ 'zh_CN' : '界面设置', /*简体*/ 'zh_TW' : '界面设置1', /*繁体*/ 'en_GB' : '界面设置2', /*英语*/ 'jp_JP' : '界面设置3' /*日语*/ }, 'class:localTool_4_159' : { /*要翻译的字符串*/ 'auto_detected' : '语言配置', /*自动检测*/ 'zh_CN' : '语言配置', /*简体*/ 'zh_TW' : '语言配置1', /*繁体*/ 'en_GB' : '语言配置2', /*英语*/ 'jp_JP' : '语言配置3' /*日语*/ }, 'class:localTool_4_160' : { /*要翻译的字符串*/ 'auto_detected' : '自动检测(简体中文)', /*自动检测*/ 'zh_CN' : '自动检测(简体中文)', /*简体*/ 'zh_TW' : '自动检测(简体中文)1', /*繁体*/ 'en_GB' : '自动检测(简体中文)2', /*英语*/ 'jp_JP' : '自动检测(简体中文)3' /*日语*/ }, 'class:localTool_4_161' : { /*要翻译的字符串*/ 'auto_detected' : '简体中文', /*自动检测*/ 'zh_CN' : '简体中文', /*简体*/ 'zh_TW' : '简体中文1', /*繁体*/ 'en_GB' : '简体中文2', /*英语*/ 'jp_JP' : '简体中文3' /*日语*/ }, 'class:localTool_4_162' : { /*要翻译的字符串*/ 'auto_detected' : '繁体中文', /*自动检测*/ 'zh_CN' : '繁体中文', /*简体*/ 'zh_TW' : '繁体中文1', /*繁体*/ 'en_GB' : '繁体中文2', /*英语*/ 'jp_JP' : '繁体中文3' /*日语*/ }, 'class:localTool_4_163' : { /*要翻译的字符串*/ 'auto_detected' : 'English', /*自动检测*/ 'zh_CN' : 'English', /*简体*/ 'zh_TW' : 'English1', /*繁体*/ 'en_GB' : 'English2', /*英语*/ 'jp_JP' : 'English3' /*日语*/ }, 'class:localTool_4_164' : { /*要翻译的字符串*/ 'auto_detected' : '主题切换', /*自动检测*/ 'zh_CN' : '主题切换', /*简体*/ 'zh_TW' : '主题切换1', /*繁体*/ 'en_GB' : '主题切换2', /*英语*/ 'jp_JP' : '主题切换3' /*日语*/ }, 'class:localTool_4_165' : { /*要翻译的字符串*/ 'auto_detected' : '请选择一个主题,然后点击应用', /*自动检测*/ 'zh_CN' : '请选择一个主题,然后点击应用', /*简体*/ 'zh_TW' : '请选择一个主题,然后点击应用1', /*繁体*/ 'en_GB' : '请选择一个主题,然后点击应用2', /*英语*/ 'jp_JP' : '请选择一个主题,然后点击应用3' /*日语*/ }, 'class:localTool_4_166' : { /*要翻译的字符串*/ 'auto_detected' : '应用主题', /*自动检测*/ 'zh_CN' : '应用主题', /*简体*/ 'zh_TW' : '应用主题1', /*繁体*/ 'en_GB' : '应用主题2', /*英语*/ 'jp_JP' : '应用主题3' /*日语*/ }, 'class:localTool_4_167' : { /*要翻译的字符串*/ 'auto_detected' : 'UI设置', /*自动检测*/ 'zh_CN' : 'UI设置', /*简体*/ 'zh_TW' : 'UI设置1', /*繁体*/ 'en_GB' : 'UI设置2', /*英语*/ 'jp_JP' : 'UI设置3' /*日语*/ }, 'class:localTool_4_168' : { /*要翻译的字符串*/ 'auto_detected' : '预览:', /*自动检测*/ 'zh_CN' : '预览:', /*简体*/ 'zh_TW' : '预览:1', /*繁体*/ 'en_GB' : '预览:2', /*英语*/ 'jp_JP' : '预览:3' /*日语*/ }, 'class:localTool_4_169' : { /*要翻译的字符串*/ 'auto_detected' : '主要字体颜色:', /*自动检测*/ 'zh_CN' : '主要字体颜色:', /*简体*/ 'zh_TW' : '主要字体颜色:1', /*繁体*/ 'en_GB' : '主要字体颜色:2', /*英语*/ 'jp_JP' : '主要字体颜色:3' /*日语*/ }, 'class:localTool_4_170' : { /*要翻译的字符串*/ 'auto_detected' : '主要背景颜色:', /*自动检测*/ 'zh_CN' : '主要背景颜色:', /*简体*/ 'zh_TW' : '主要背景颜色:1', /*繁体*/ 'en_GB' : '主要背景颜色:2', /*英语*/ 'jp_JP' : '主要背景颜色:3' /*日语*/ }, 'class:localTool_4_171' : { /*要翻译的字符串*/ 'auto_detected' : '留言成功字体颜色:', /*自动检测*/ 'zh_CN' : '留言成功字体颜色:', /*简体*/ 'zh_TW' : '留言成功字体颜色:1', /*繁体*/ 'en_GB' : '留言成功字体颜色:2', /*英语*/ 'jp_JP' : '留言成功字体颜色:3' /*日语*/ }, 'class:localTool_4_172' : { /*要翻译的字符串*/ 'auto_detected' : '留言失败字体颜色:', /*自动检测*/ 'zh_CN' : '留言失败字体颜色:', /*简体*/ 'zh_TW' : '留言失败字体颜色:1', /*繁体*/ 'en_GB' : '留言失败字体颜色:2', /*英语*/ 'jp_JP' : '留言失败字体颜色:3' /*日语*/ }, 'class:localTool_4_173' : { /*要翻译的字符串*/ 'auto_detected' : '留言发生错误字体颜色:', /*自动检测*/ 'zh_CN' : '留言发生错误字体颜色:', /*简体*/ 'zh_TW' : '留言发生错误字体颜色:1', /*繁体*/ 'en_GB' : '留言发生错误字体颜色:2', /*英语*/ 'jp_JP' : '留言发生错误字体颜色:3' /*日语*/ }, 'class:localTool_4_174' : { /*要翻译的字符串*/ 'auto_detected' : '保存为主题', /*自动检测*/ 'zh_CN' : '保存为主题', /*简体*/ 'zh_TW' : '保存为主题1', /*繁体*/ 'en_GB' : '保存为主题2', /*英语*/ 'jp_JP' : '保存为主题3' /*日语*/ }, 'class:localTool_4_175' : { /*要翻译的字符串*/ 'auto_detected' : '关于SteamAssistant(Steam小助手)', /*自动检测*/ 'zh_CN' : '关于SteamAssistant(Steam小助手)', /*简体*/ 'zh_TW' : '关于SteamAssistant(Steam小助手)1', /*繁体*/ 'en_GB' : '关于SteamAssistant(Steam小助手)2', /*英语*/ 'jp_JP' : '关于SteamAssistant(Steam小助手)3' /*日语*/ }, 'class:localTool_4_176' : { /*要翻译的字符串*/ 'auto_detected' : '程序信息:', /*自动检测*/ 'zh_CN' : '程序信息:', /*简体*/ 'zh_TW' : '程序信息:1', /*繁体*/ 'en_GB' : '程序信息:2', /*英语*/ 'jp_JP' : '程序信息:3' /*日语*/ }, 'class:localTool_4_177' : { /*要翻译的字符串*/ 'auto_detected' : '当前版本:v0.2.3.0', /*自动检测*/ 'zh_CN' : '当前版本:v0.2.3.0', /*简体*/ 'zh_TW' : '当前版本:v0.2.3.01', /*繁体*/ 'en_GB' : '当前版本:v0.2.3.02', /*英语*/ 'jp_JP' : '当前版本:v0.2.3.03' /*日语*/ }, 'class:localTool_4_178' : { /*要翻译的字符串*/ 'auto_detected' : '主程序框架更新时间:2020年4月19日', /*自动检测*/ 'zh_CN' : '主程序框架更新时间:2020年4月19日', /*简体*/ 'zh_TW' : '主程序框架更新时间:2020年4月19日1', /*繁体*/ 'en_GB' : '主程序框架更新时间:2020年4月19日2', /*英语*/ 'jp_JP' : '主程序框架更新时间:2020年4月19日3' /*日语*/ }, 'class:localTool_4_179' : { /*要翻译的字符串*/ 'auto_detected' : 'common模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'common模块:2020年4月19日', /*简体*/ 'zh_TW' : 'common模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'common模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'common模块:2020年4月19日3' /*日语*/ }, 'class:localTool_4_180' : { /*要翻译的字符串*/ 'auto_detected' : 'databaseConf模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'databaseConf模块:2020年4月19日', /*简体*/ 'zh_TW' : 'databaseConf模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'databaseConf模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'databaseConf模块:2020年4月19日3' /*日语*/ }, 'class:localTool_4_181' : { /*要翻译的字符串*/ 'auto_detected' : 'externalApis模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'externalApis模块:2020年4月19日', /*简体*/ 'zh_TW' : 'externalApis模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'externalApis模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'externalApis模块:2020年4月19日3' /*日语*/ }, 'class:localTool_4_182' : { /*要翻译的字符串*/ 'auto_detected' : 'steamApis模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'steamApis模块:2020年4月19日', /*简体*/ 'zh_TW' : 'steamApis模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'steamApis模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'steamApis模块:2020年4月19日3' /*日语*/ }, 'class:localTool_4_183' : { /*要翻译的字符串*/ 'auto_detected' : 'translateApis模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'translateApis模块:2020年4月19日', /*简体*/ 'zh_TW' : 'translateApis模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'translateApis模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'translateApis模块:2020年4月19日3' /*日语*/ }, 'class:localTool_4_184' : { /*要翻译的字符串*/ 'auto_detected' : 'Utility模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'Utility模块:2020年4月19日', /*简体*/ 'zh_TW' : 'Utility模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'Utility模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'Utility模块:2020年4月19日3' /*日语*/ }, 'class:localTool_4_185' : { /*要翻译的字符串*/ 'auto_detected' : 'UI模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'UI模块:2020年4月19日', /*简体*/ 'zh_TW' : 'UI模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'UI模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'UI模块:2020年4月19日3' /*日语*/ }, 'class:localTool_4_186' : { /*要翻译的字符串*/ 'auto_detected' : 'Event模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'Event模块:2020年4月19日', /*简体*/ 'zh_TW' : 'Event模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'Event模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'Event模块:2020年4月19日3' /*日语*/ }, 'class:localTool_4_187' : { /*要翻译的字符串*/ 'auto_detected' : 'CityList模块:2020年4月19日', /*自动检测*/ 'zh_CN' : 'CityList模块:2020年4月19日', /*简体*/ 'zh_TW' : 'CityList模块:2020年4月19日1', /*繁体*/ 'en_GB' : 'CityList模块:2020年4月19日2', /*英语*/ 'jp_JP' : 'CityList模块:2020年4月19日3' /*日语*/ }, 'class:localTool_4_188' : { /*要翻译的字符串*/ 'auto_detected' : '联系作者:', /*自动检测*/ 'zh_CN' : '联系作者:', /*简体*/ 'zh_TW' : '联系作者:1', /*繁体*/ 'en_GB' : '联系作者:2', /*英语*/ 'jp_JP' : '联系作者:3' /*日语*/ }, 'class:localTool_4_189' : { /*要翻译的字符串*/ 'auto_detected' : '反馈错误', /*自动检测*/ 'zh_CN' : '反馈错误', /*简体*/ 'zh_TW' : '反馈错误1', /*繁体*/ 'en_GB' : '反馈错误2', /*英语*/ 'jp_JP' : '反馈错误3' /*日语*/ }, } }; var languagesList_mainUI_template = { 'defaultLanguage' : 'zh_CN', /* (optional) although must be defined if you don't want en_GB */ 'showFlag': true, /* (optional) show/hide the flag ��ʾ/�������� */ 'showCountry': true, /* (optional) show/hide the country name ��ʾ/���ع������� */ 'showLanguage': true, /* (optional) show/hide the country language ��ʾ/���ع������� */ 'languages' : { /* (optional) define **ADDITIONAL** custom languages ����**�����**�Զ������� */ 'italian' : { 'country': 'Italy', 'language' : 'Italian', 'countryTranslated': 'Italia', 'languageTranslated': 'Italiano', 'flag' : { 'url' : 'http://upload.wikimedia.org/wikipedia/commons/f/fb/Farm-Fresh_italy.png', /* url of flag image ��־ͼ��url */ 'class' : 'italian-flag' /* (optional) class to assign to the flag (e.g., for css styling) �����������־(���磬����css��ʽ) */ } }, 'barletta-dialect' : { 'country': 'Barletta', 'language' : 'Barlettano', 'countryTranslated': 'Barlett', 'languageTranslated': "Barlett'n", 'flag': { 'url' : 'http://upload.wikimedia.org/wikipedia/commons/2/20/Flag_of_Barletta.png' } } }, /* * Translate your strings below ����������ַ��� */ 'strings' : { } }; var languagesList_winBaseFrame = { 'defaultLanguage' : 'zh_CN', /* (optional) although must be defined if you don't want en_GB */ 'showFlag': true, /* (optional) show/hide the flag ��ʾ/�������� */ 'showCountry': true, /* (optional) show/hide the country name ��ʾ/���ع������� */ 'showLanguage': true, /* (optional) show/hide the country language ��ʾ/���ع������� */ 'languages' : { /* (optional) define **ADDITIONAL** custom languages ����**�����**�Զ������� */ 'italian' : { 'country': 'Italy', 'language' : 'Italian', 'countryTranslated': 'Italia', 'languageTranslated': 'Italiano', 'flag' : { 'url' : 'http://upload.wikimedia.org/wikipedia/commons/f/fb/Farm-Fresh_italy.png', /* url of flag image ��־ͼ��url */ 'class' : 'italian-flag' /* (optional) class to assign to the flag (e.g., for css styling) �����������־(���磬����css��ʽ) */ } }, 'barletta-dialect' : { 'country': 'Barletta', 'language' : 'Barlettano', 'countryTranslated': 'Barlett', 'languageTranslated': "Barlett'n", 'flag': { 'url' : 'http://upload.wikimedia.org/wikipedia/commons/2/20/Flag_of_Barletta.png' } } }, /* * Translate your strings below ����������ַ��� */ 'strings' : { } }; /** * uiStyle.js */ /** * steamNetData.js * @file 存储利用网络请求来获取steam相关数据的代码 [steam网络数据] */ function getBaseInfo(rank){ var info3 = { language: "", name: "", url: "", steamID64: "", steamCustomUrl: "", accountId: "", confInfoObj: null, userInfoObj: null }; var info2 = { language: "", name: "", url: "", steamID64: "", steamCustomUrl: "", accountId: "", }; var info1 = { language: "", name: "", url: "", steamID64: "", accountId: "", }; switch (rank){ case 0: if(typeof g_steamID != "undefined" && typeof g_steamID == "string" && g_steamID.test(g_steamId64RegExp)) return g_steamID; else { var obj = document.getElementById('webui_config'); if(obj){ userInfoStr = obj.getAttribute('data-userinfo'); userInfoObj = JSON.parse(userInfoStr); var userInfoObj; return userInfoObj.steamid; } } break; case 1: break; case 2: break; case 3: break; default: break; } // if(g_rgProfileData && typeof g_rgProfileData == "object"){ // info.name = g_rgProfileData.personaname; // info.url = g_rgProfileData.url; // info.steamID64 = g_rgProfileData.steamid; // } // //https://steamcommunity.com/profiles/76561198373290430/edit // //<input class="dynInput" type="text" name="customURL" id="customURL" value="miku-39"> // if(g_steamID && typeof g_steamID == "string" && g_steamID.test(g_steamId64RegExp)) // info.steamID64 = g_steamID; // else // { // var obj = document.getElementById('webui_config'); // var confInfoStr,userInfoStr; // var confInfoObj,userInfoObj; // if(obj){ // confInfoStr = obj.getAttribute('data-config'); // userInfoStr = obj.getAttribute('data-userinfo'); // confInfoObj = JSON.parse(confInfoStr); // userInfoObj = JSON.parse(userInfoStr); // info.confInfoObj = confInfoObj; // info.userInfoObj = userInfoObj; // info.steamID64 = userInfoObj.steamid // info.steamCustomUrl = ""; // info.accountId = userInfoObj.accountid; // info.language = confInfoObj.language; // } // } } /** * http://www.openjs.com/scripts/events/keyboard_shortcuts/ * Version : 2.01.B * By Binny V A * License : BSD */ shortcut = { 'all_shortcuts':{},//All the shortcuts are stored in this array 'add': function(shortcut_combination,callback,opt) { //Provide a set of default options var default_options = { 'type':'keydown', 'disable_in_input':false, 'target':document, 'keycode':false } if(!opt) opt = default_options; else { for(var dfo in default_options) { if(typeof opt[dfo] == 'undefined') opt[dfo] = default_options[dfo]; } } var ele = opt.target; if(typeof opt.target == 'string') ele = document.getElementById(opt.target); var ths = this; shortcut_combination = shortcut_combination.toLowerCase(); //The function to be called at keypress var func = function(e) { e = e || window.event; if(opt['disable_in_input']) { //Don't enable shortcut keys in Input, Textarea fields var element; if(e.target) element=e.target; else if(e.srcElement) element=e.srcElement; if(element.nodeType==3) element=element.parentNode; if(element.tagName == 'INPUT' || element.tagName == 'TEXTAREA') return; } //Find Which key is pressed if (e.keyCode) code = e.keyCode; else if (e.which) code = e.which; var character = String.fromCharCode(code).toLowerCase(); if(code == 188) character=","; //If the user presses , when the type is onkeydown if(code == 190) character="."; //If the user presses , when the type is onkeydown var keys = shortcut_combination.split("+"); //Key Pressed - counts the number of valid keypresses - if it is same as the number of keys, the shortcut function is invoked var kp = 0; //Work around for stupid Shift key bug created by using lowercase - as a result the shift+num combination was broken var shift_nums = { "`":"~", "1":"!", "2":"@", "3":"#", "4":"$", "5":"%", "6":"^", "7":"&", "8":"*", "9":"(", "0":")", "-":"_", "=":"+", ";":":", "'":"\"", ",":"<", ".":">", "/":"?", "\\":"|" } //Special Keys - and their codes var special_keys = { 'esc':27, 'escape':27, 'tab':9, 'space':32, 'return':13, 'enter':13, 'backspace':8, 'scrolllock':145, 'scroll_lock':145, 'scroll':145, 'capslock':20, 'caps_lock':20, 'caps':20, 'numlock':144, 'num_lock':144, 'num':144, 'pause':19, 'break':19, 'insert':45, 'home':36, 'delete':46, 'end':35, 'pageup':33, 'page_up':33, 'pu':33, 'pagedown':34, 'page_down':34, 'pd':34, 'left':37, 'up':38, 'right':39, 'down':40, 'f1':112, 'f2':113, 'f3':114, 'f4':115, 'f5':116, 'f6':117, 'f7':118, 'f8':119, 'f9':120, 'f10':121, 'f11':122, 'f12':123, } var modifiers = { shift: { wanted:false, pressed:false}, ctrl : { wanted:false, pressed:false}, alt : { wanted:false, pressed:false}, meta : { wanted:false, pressed:false} //Meta is Mac specific }; if(e.ctrlKey) modifiers.ctrl.pressed = true; if(e.shiftKey) modifiers.shift.pressed = true; if(e.altKey) modifiers.alt.pressed = true; if(e.metaKey) modifiers.meta.pressed = true; for(var i=0; k=keys[i],i<keys.length; i++) { //Modifiers if(k == 'ctrl' || k == 'control') { kp++; modifiers.ctrl.wanted = true; } else if(k == 'shift') { kp++; modifiers.shift.wanted = true; } else if(k == 'alt') { kp++; modifiers.alt.wanted = true; } else if(k == 'meta') { kp++; modifiers.meta.wanted = true; } else if(k.length > 1) { //If it is a special key if(special_keys[k] == code) kp++; } else if(opt['keycode']) { if(opt['keycode'] == code) kp++; } else { //The special keys did not match if(character == k) kp++; else { if(shift_nums[character] && e.shiftKey) { //Stupid Shift key bug created by using lowercase character = shift_nums[character]; if(character == k) kp++; } } } } if(kp == keys.length && modifiers.ctrl.pressed == modifiers.ctrl.wanted && modifiers.shift.pressed == modifiers.shift.wanted && modifiers.alt.pressed == modifiers.alt.wanted && modifiers.meta.pressed == modifiers.meta.wanted) { callback(e); if(!opt['propagate']) { //Stop the event //e.cancelBubble is supported by IE - this will kill the bubbling process. e.cancelBubble = true; e.returnValue = false; //e.stopPropagation works in Firefox. if (e.stopPropagation) { e.stopPropagation(); e.preventDefault(); } return false; } } } this.all_shortcuts[shortcut_combination] = { 'callback':func, 'target':ele, 'event': opt['type'] }; //Attach the function with the event if(ele.addEventListener) ele.addEventListener(opt['type'], func, false); else if(ele.attachEvent) ele.attachEvent('on'+opt['type'], func); else ele['on'+opt['type']] = func; }, //Remove the shortcut - just specify the shortcut and I will remove the binding 'remove':function(shortcut_combination) { shortcut_combination = shortcut_combination.toLowerCase(); var binding = this.all_shortcuts[shortcut_combination]; delete(this.all_shortcuts[shortcut_combination]) if(!binding) return; var type = binding['event']; var ele = binding['target']; var callback = binding['callback']; if(ele.detachEvent) ele.detachEvent('on'+type, callback); else if(ele.removeEventListener) ele.removeEventListener(type, callback, false); else ele['on'+type] = false; } } /** * websocket.js */ // //https://blog.csdn.net/CaptainJava/article/details/102853088 class Socket { constructor(arg) { this.webSocketObj = null; this.fRecvCallBack = null; } /** * @param {String} url 目标通讯url * @param {Function} recvCallBack 接收到数据后的回调函数(处理函数) * @return {Boolean} true: webSocket初始化成功,false: webSocket初始化失败 */ init(url,recvCallBack){ var URL; if(url){ URL = url; } else{ URL = "ws://" + window.location.host + "/websocket/message"; } if(recvCallBack){ this.fRecvCallBack = recvCallBack; } //判断当前浏览器是否支持WebSocket if ('WebSocket' in window) { this.webSocketObj = new WebSocket(URL); } else { alert('Dont support websocket!'); return false; } //连接发生错误的回调方法 this.webSocketObj.onerror = function () { console.log("webSocket error!"); }; //连接成功建立的回调方法 this.webSocketObj.onopen = function () { console.log("webSocket connected."); }; //接收到消息的回调方法 this.webSocketObj.onmessage = function (event) { console.log("webSocket收到数据!"); if(this.fRecvCallBack){ this.fRecvCallBack(); } }; //连接关闭的回调方法 this.webSocketObj.onclose = function () { console.log("webSocket close"); }; window.addEventListener("beforeunload", function(event) { this.webSocketObj.close(); }); return true; } //关闭连接 close() { return this.webSocketObj.close(); } //发送消息 send(message) { return this.webSocketObj.send(message); } } function recvHander(){ var obj = JSON.parse(event.data); if(obj && "message" == obj.type){ console.log(obj.data); // table.reload('test', { // elem: '#test' // ,data: JSON.parse(obj.data) // }); } } function test_websocket(){ var socket = new Socket(); socket.init("",recvHander); socket.send("Hello!"); socket.close(); } /** * translateApis.js */ //------------------------------------------------------------------------------------------------------------- // 翻译API /*-------------------------------------------------*/ var b = function(a, b) { for (var d = 0; d < b.length - 2; d += 3) { var c = b.charAt(d + 2), c = "a" <= c ? c.charCodeAt(0) - 87 : Number(c), c = "+" == b.charAt(d + 1) ? a >>> c : a << c; a = "+" == b.charAt(d) ? a + c & 4294967295 : a ^ c } return a } var tk = function(a, TKK) { for (var e = TKK.split("."), h = Number(e[0]) || 0, g = [], d = 0, f = 0; f < a.length; f++) { var c = a.charCodeAt(f); 128 > c ? g[d++] = c : (2048 > c ? g[d++] = c >> 6 | 192 : (55296 == (c & 64512) && f + 1 < a.length && 56320 == (a.charCodeAt( f + 1) & 64512) ? (c = 65536 + ((c & 1023) << 10) + (a.charCodeAt(++f) & 1023), g[d++] = c >> 18 | 240, g[d++] = c >> 12 & 63 | 128) : g[d++] = c >> 12 | 224, g[d++] = c >> 6 & 63 | 128), g[d++] = c & 63 | 128) } a = h; for (d = 0; d < g.length; d++) a += g[d], a = b(a, "+-a^+6"); a = b(a, "+-3^+b+-f"); a ^= Number(e[1]) || 0; 0 > a && (a = (a & 2147483647) + 2147483648); a %= 1E6; return a.toString() + "." + (a ^ h) } /*-------------------------------------------------*/ var auto = "auto"; //自动检测 var zhc = "zh-CN"; //中文简体 var zht = "zh-TW"; //中文繁体 var en = "en"; //英语 var jp = "ja"; //日语 var waitStatus = true; //等待状态 var waitStatus_cn = true; //等待状态 var returnData; var returnData_cn; async function GoogleTranslateRequest(origLanguage, newLanguage, strText) { waitStatus = true; var _tkk = "439786.2762026697"; var _tk = tk(strText, _tkk); //console.log("_tk:",_tk); //https://translate.google.cn/#view=home&op=translate&sl=auto&tl=zh-CN&text=12312 //https://translate.google.com.hk/?hl=zh-CN&tab=TT#view=home&op=translate&sl=auto&tl=zh-CN&text=123123 //https://translate.google.com/?hl=zh-CN#view=home&op=translate&sl=auto&tl=zh-CN&text=111 //https://translate.google.com.tw/#view=home&op=translate&sl=auto&tl=ja&text=%E4%BD%A0%E5%A5%BD //谷歌翻译app抓包 //第三方getpost请求代发送 //https://translate.google.cn/translate_a/single?client=t //需要拼接的url序列 var baseURL = "https://translate.google.cn/translate_a/single?"; var baseURL1 = "https://translate.google.com/translate_a/single?"; var client = "client=" + "webapp"; var sl = "&sl=" + origLanguage; //待翻译的原始语言 //默认为auto,即自动检测语言 var tl = "&tl=" + newLanguage; //需要翻译成什么语言 //默认为zh-CN,即默认翻译为中文 var hl = "&hl=" + zhc; var dt1 = "&dt=at&"; var dt2 = "dt=bd&"; var dt3 = "dt=ex&"; var dt4 = "dt=ld&"; var dt5 = "dt=md&"; var dt6 = "dt=qca&"; var dt7 = "dt=rw&"; var dt8 = "dt=rm&"; var dt9 = "dt=ss&"; var dt0 = "dt=t&"; var dt = "dt=gt&"; //del var otf = "otf=2&"; //1 var ssel = "ssel=0&"; var tsel = "tsel=4&"; //0 var xid = "xid=1782844&"; var kc = "kc=1&"; //8 //2 var Tk = "tk=" + _tk; var q = "&q=" + encodeURI(strText); var requestURL = baseURL + client + sl + tl + hl + dt1 + dt2 + dt3 + dt4 + dt5 + dt6 + dt7 + dt8 + dt9 + dt0 + dt + otf + ssel + tsel + xid + kc + Tk + q; //console.log("requestURL: ",requestURL); GM_xmlhttpRequest({ method: 'GET', url: requestURL, headers: { 'User-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.122 Safari/537.36', //'Accept': 'application/atom+xml,application/xml,text/xml', //"Content-Type": "application/x-www-form-urlencoded", }, onload: function(response) { if (response.status === 200) { console.log('请求成功!'); var JSON_jsObj = JSON_processing_parsing_JsObj(response.responseText); //遍历[0][0]数组就可以取得翻译后的文本,原始数据,原始数据的拼音 //[2]是检查出的语言 //遍历[5]可以取得两种翻译,原始数据和原始数据的长度 //遍历[8]可以得到原始语言和翻译语言 //for (var i = 0; i < JSON_jsObj.length; i++) { // for (var j = 0; j < JSON_jsObj[i].length; j++) { // for (var k = 0; k < JSON_jsObj[i][j].length; k++) { // // } // } //} var retData = ""; for (var j = 0; j < JSON_jsObj[0].length; j++) { if (JSON_jsObj[0][j][0] != null) { retData += JSON_jsObj[0][j][0]; //组合每一句翻译 } } returnData = retData; //存储数据 //console.log('谷歌翻译:',retData); waitStatus = false; //不等待 //console.log(response); //console.log(response.responseText); //if(response.responseText.indexOf('[[["') == 0) //是否是指定的数据格式 //{ // var retData = response.responseText.slice(4,response.responseText.indexOf('","',4)); //提取翻译后的文本 // returnData = retData; //存储数据 // //console.log('谷歌翻译:',retData); // waitStatus = false; //不等待 //} } else { console.log('请求失败!'); //console.log(response); //console.log(response.responseText); } }, onerror: function(err) { console.log('请求错误!', err); } }); while (waitStatus) //强制等待异步函数执行完毕后再执行 { console.log("wait..."); await sleep(100); //延迟0.1秒 } return returnData; // jQuery.ajax({ // url: URL, // type: "GET", // dataType: "jsonp", //指定服务器返回的数据类型 // jsonp: "callback", //Jquery生成验证参数的名称 // processData: false, // success: function (data) { // //var result = JSON.stringify(data); //json对象转成字符串 // console.log("GET成功!",data); // }, // error: function(XMLHttpRequest, textStatus, errorThrown) { // alert(XMLHttpRequest.status); // alert(XMLHttpRequest.readyState); // alert(textStatus); // } // }); // jQuery.get(URL,function(response,status,xhr){ // if (response.success === false) { // console.log("GET失败了!",response); // } else { // console.log("GET成功!",response); // } // },"json"); // jQuery.post(URL, { // comment: newMgs, // count: 6, // sessionid: g_sessionID // }, function(response) { // if (response.success === false) { // console.log("留言失败了!"); // } else { // console.log("成功发表评论于"); // } // }).fail(function() { // console.log("无法发表评论于"); // }).always(function() { // console.log("当前处理了 " + (i + 1) + "个, 总计 " + total + " 个好友."); // }); } async function CNTranslateRequest(newLanguage, strText) { //简体转各类繁体,各类繁体转简体 waitStatus_cn = true; var baseURL = "https://brushes8.com/zhong-wen-jian-ti-fan-ti-zhuan-huan"; GM_xmlhttpRequest({ method: 'POST', url: baseURL, data: "data=" + encodeURI(strText) + "&dochineseconversion=" + "1" + "&variant=" + newLanguage + "&submit=" + encodeURI("开始转换 (Ctrl + Enter)"), headers: { "accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9", "Content-Type": "application/x-www-form-urlencoded", //非常重要 "User-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.122 Safari/537.36", }, onload: function(response) { if (response.status === 200) { console.log('请求成功!'); var findStr = '<label for="response">转换结果: </label><br /><textarea id="response" rows="15" cols="150">'; var retData = response.responseText.slice(response.responseText.lastIndexOf(findStr) + findStr.length); returnData_cn = retData; //存储数据 //console.log('谷歌翻译:',retData); waitStatus_cn = false; //不等待 } else { console.log('请求失败!', response); //console.log(response); //console.log(response.responseText); } }, onerror: function(err) { console.log('请求错误!', err); } }); while (waitStatus_cn) //强制等待异步函数执行完毕后再执行 { console.log("wait..."); await sleep(100); //延迟0.1秒 } return returnData_cn; } //--------------------------------- // DEEP翻译API //--------------------------------- var default_request_pack = { //默认请求包 "jsonrpc": "2.0", "method": "LMT_handle_jobs", //方法 "params": { //参数 "jobs": [ //工作 { "kind": "default", //种类 "raw_en_sentence": "你好世界", //原始句子 "raw_en_context_before": [], //之前的原始环境(上下文) "raw_en_context_after": [], //之后的原始环境(上下文) "preferred_num_beams": 4, //首选数字 "quality": "fast", //质量 }, ], "lang": { //语言 "user_preferred_langs": ["EN", "ZH"], //用户首选语言 "source_lang_user_selected": "auto", //源语言(用户选择) "target_lang": "EN", //目标语言 }, "priority": -1, //优先级 "commonJobParams": {}, //常见的工作参数 "timestamp": 1591090077383, //时间戳 }, "id": 92910013, }; var default_split_pack = { //默认分解包(句子拆分再请求) "jsonrpc": "2.0", "method": "LMT_split_into_sentences", //方法 "params": { //参数 "lang": { //语言 "lang_user_selected": "auto", //用户选择语言 "user_preferred_langs": ["EN", "ZH"] //用户首选语言 } }, "id": 92910016 }; var default_split_request_pack = { //默认分解请求包 "jsonrpc": "2.0", "method": "LMT_handle_jobs", //方法 "params": { //参数 "jobs": [ //工作 { "kind": "default", //种类 "raw_en_sentence": "没有人富有得可以不要别人的帮助,也没有人穷得不能在某方面给他人帮助。", //原始句子 "raw_en_context_before": [], //之前的原始环境(上下文) "raw_en_context_after": ["凡真心尝试助人者,没有不帮到自己的。"], //之后的原始环境(上下文) "preferred_num_beams": 1 //首选数字 }, { "kind": "default", //种类 "raw_en_sentence": "凡真心尝试助人者,没有不帮到自己的。", //原始句子 "raw_en_context_before": ["没有人富有得可以不要别人的帮助,也没有人穷得不能在某方面给他人帮助。"], //之前的原始环境(上下文) "raw_en_context_after": [], //之后的原始环境(上下文) "preferred_num_beams": 1 //首选数字 }, ], "lang": { //语言 "user_preferred_langs": ["EN", "ZH"], //用户首选语言 "source_lang_computed": "ZH", //源语言(计算后的) "target_lang": "EN" //目标语言 }, "priority": 1, //优先级 "commonJobParams": {}, //常见的工作参数 "timestamp": 1591091506769 //时间戳 }, "id": 92910017 }; var default_verification_pack = { //默认验证包 "jsonrpc": "2.0", "method": "getClientState", //方法 "params": { //参数 "v": "20180814", //版本 "clientVars": { //客户端值 "userCountry": "CN", //用户国家 "showAppPopup": true, //显示应用程序弹出 "uid": "a3eb6359-c34e-4f9f-b39d-f7dc71187afc", //用户唯一标识符 "testGroupId": 6243, //测试组Id "testGroupIdIsNew": true, //测试组Id是新的 "useStatisticsApiV2": true, //使用统计Api V2 }, }, "id": 92910010, }; function deepTranslateRequest() { } /** * externalApis.js */ class intelligenceAI //智能AI模块 { constructor(name) { //public 构造方法 this.arrCityCode; this.baseWeatherURL = "https://api.help.bj.cn/"; } getWeather(strCityName){ //public 获取天气(城市代码字符串) let URL = this.baseWeatherURL + "apis/weather2d/?id=" + strCityName; //生成URL $.ajax({ type: "Get", //请求方式 //async: false, //contentType: "application/json;charset=UTF-8",//请求的媒体类型 url: URL, //请求地址 // headers: { // 'User-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.122 Safari/537.36', // //'Accept': 'application/atom+xml,application/xml,text/xml', // //"Content-Type": "application/x-www-form-urlencoded", // }, //data: JSON.stringify(list), //数据,json字符串 success: function(result) { //请求成功 //let Data = JSON_processing_parsing_JsObj(result); console.log("Data",result); }, error: function(e) { //请求失败,包含具体的错误信息 console.log("请求失败了!", e.status); console.log("请求失败了!", e.responseText); } }); } } //------------------------------------------------------------------------------------------------------------- class externalApis{ constructor(){ this.urls = [ { name: "mz-moe.cn", //名称 describe: "https://mz-moe.cn/?p=23", //描述 trait: "Support files only,https,406张图片(2019.8.12)", //特征 request: "get", //请求方式 mainUrl: "https://api.mz-moe.cn/", //基础url library: [ { name: "随机动漫图片api", //https://api.dongmanxingkong.com/suijitupian.html Url: "img.php", //功能url(部分) Url1: "", //功能url1(部分) parameter: "", //参数 parameter1: "" //参数1(另外一种类型) }, ] },{ name: "樱花", //名称 describe: "http://www.dmoe.cc/", //描述 trait: "http->https,1000+(2020-03-12)", //特征 request: "get", //请求方式 mainUrl: "http://www.dmoe.cc/", //基础url library: [ { name: "随机二次元图片API", //https://api.dongmanxingkong.com/suijitupian.html Url: "random.php", //功能url(部分) Url1: "", //功能url1(部分) parameter: "?return=json", //参数 parameter1: "type=json" //参数1(另外一种类型) }, ] },{ name: "动漫星空", //名称 describe: "https://api.dongmanxingkong.com/", //描述 trait: "https,8千万+张4K精美图片,文字二维码生成", //特征 request: "get", //请求方式 mainUrl: "https://api.dongmanxingkong.com/", //基础url library: [ { name: "随机图片API", //https://api.dongmanxingkong.com/suijitupian.html Url: ["suijitupian/acg/1080p/","suijitupian/acg/2k/","suijitupian/acg/4k/"], //功能url(部分) Url1: "index.php", //功能url1(部分) parameter: "?return=json", //参数 parameter1: "type=json" //参数1(另外一种类型) },{ name: "二维码API", //https://api.dongmanxingkong.com/qr.html Url: "qr/?text=", //功能url(部分) Url1: "&size=150", //功能url1(部分) parameter: "", //参数 parameter1: "" //参数1(另外一种类型) } ] },{ name: "LRY_API(聚合漫画、影视、小说等接口)", //名称 describe: "http://api.pingcc.cn/", //描述 trait: "warn redirection,http,综合搜索,漫画,影视,小说", //特征 request: "get", //请求方式 mainUrl: "http://api.pingcc.cn/", //基础url library: [ { name: "综合搜索", //https://api.dongmanxingkong.com/suijitupian.html Url: "?name=", //功能url(部分) Url1: "", //功能url1(部分) parameter: "", //参数 parameter1: "" //参数1(另外一种类型) },{ name: "漫画API接口", //https://api.dongmanxingkong.com/qr.html Url: "?mhname=", //功能url(部分) Url1: ["?mhurl1=","?mhurl2="], //功能url1(部分) //通过mhurl2获取到的是漫画图片,按顺序排列 parameter: "", //参数 parameter1: "" //参数1(另外一种类型) },{ name: "影视API接口", //https://api.dongmanxingkong.com/qr.html Url: "?ysname=", //功能url(部分) Url1: "?ysurl=", //功能url1(部分) parameter: "", //参数 parameter1: "" //参数1(另外一种类型) },{ name: "小说API接口", //https://api.dongmanxingkong.com/qr.html Url: "?xsname=", //功能url(部分) Url1: ["?xsurl1=","?xsurl2="], //功能url1(部分) //通过xsurl2获取到的是小说内容 parameter: "", //参数 parameter1: "" //参数1(另外一种类型) } ] },{ name: "宅言API", //名称 describe: "https://www.kancloud.cn/acman/zhaiyanapi/31183", //描述 trait: "https,动漫台词,角色资料,番组信息接口", //特征 request: "get", //请求方式 mainUrl: "https://zhaiyan.2cys.com/api", //基础url library: [ { name: "获取随机库中台词", //https://www.kancloud.cn/acman/zhaiyanapi/367018 Url: "/taici/rands", //功能url(部分) Url1: "", //功能url1(部分) parameter: "?type=json", //参数 parameter1: "json(默认)/xml/text" //参数1(另外一种类型) },{ name: "根据库ID获取台词", //https://www.kancloud.cn/acman/zhaiyanapi/367019 Url: "/taici/id", //功能url(部分) Url1: "", //功能url1(部分) //通过mhurl2获取到的是漫画图片,按顺序排列 parameter: "?id=", //参数 parameter1: "?type=json" //参数1(另外一种类型) },{ name: "根据作品名获取数据", //https://www.kancloud.cn/acman/zhaiyanapi/367152 Url: "/taici/names", //功能url(部分) Url1: "", //功能url1(部分) parameter: "?name=", //参数 parameter1: ["?rand=0","?type=json"] //参数1(其他参数) },{ name: "动漫角色资料接口", //https://www.kancloud.cn/acman/zhaiyanapi/48115 Url: "", //功能url(部分) Url1: "", //功能url1(部分) //通过xsurl2获取到的是小说内容 parameter: "", //参数 parameter1: "" //参数1(另外一种类型) },{ name: "获取随机库中番组", //https://www.kancloud.cn/acman/zhaiyanapi/368479 Url: "/bangumi/rands", //功能url(部分) Url1: "", //功能url1(部分) //通过xsurl2获取到的是小说内容 parameter: "?type=json", //参数 parameter1: "" //参数1(另外一种类型) } ] } ]; } getUrlInfo(){ console.log(this.urls); } async getDataByApiList(platformsID,apiId,type,name){ //参数: 平台id(区别不同平台提供的api),要调用的api的id(区分是要调用的是什么api),类型(调用api可能需要提供的参数),名称(调用api可能需要提供的参数) switch (platformsID){ case 0: var obj = this.urls[0]; //mz-moe.cn var lib = obj.library[0]; //随机动漫图片api var url = obj.mainUrl + lib.Url; console.log("url",url); var jsData = await getResourceByURL(url,true); //随机动漫图片api console.log("数据获取成果",jsData); return jsData; break; case 1: var obj = this.urls[1]; //樱花 var lib = obj.library[0]; //随机二次元图片API console.log("url",url); var url = obj.mainUrl + lib.Url; if(type == "json") url += lib.parameter; var jsData = await getResourceByURL(url,true); //随机二次元图片API console.log("数据获取成果",jsData); return jsData; break; case 2: var obj = this.urls[2]; //动漫星空 var lib = obj.library[0]; //随机图片API var lib1 = obj.library[1]; //二维码API var url = obj.mainUrl + lib.Url[0] + lib.Url1; if(type == "json") url += lib.parameter; var url1 = obj.mainUrl + lib1.Url + name + lib1.Url1; console.log("url",url,"url1",url1); var jsData; if(apiId == 0){ jsData = await getResourceByURL(url,true); //随机图片API }else if(apiId == 1){ jsData = await getResourceByURL(url1,true); //二维码API } console.log("数据获取成果",jsData); return jsData; break; case 3: var obj = this.urls[3]; //LRY_API(聚合漫画、影视、小说等接口) var lib = obj.library[0]; //综合搜索 var lib1 = obj.library[1]; //漫画API接口 var lib2 = obj.library[2]; //影视API接口 var lib3 = obj.library[3]; //小说API接口 var url = obj.mainUrl + lib.Url + name; var url1 = obj.mainUrl + lib1.Url + name; var url2 = obj.mainUrl + lib2.Url + name; var url3 = obj.mainUrl + lib3.Url + name; console.log("url",url,"url1",url1,"url2",url2,"url3",url3); var jsData; if(apiId == 0){ jsData = await getResourceByURL(url,true); //综合搜索 }else if(apiId == 1){ jsData = await getResourceByURL(url1,true); //漫画API接口 }else if(apiId == 2){ jsData = await getResourceByURL(url2,true); //影视API接口 }else if(apiId == 3){ jsData = await getResourceByURL(url3,true); //小说API接口 } console.log("数据获取成果",jsData); return jsData; break; case 4: var obj = this.urls[4]; //宅言API var lib = obj.library[0]; //获取随机库中台词 var lib1 = obj.library[1]; //根据库ID获取台词 var lib2 = obj.library[2]; //根据作品名获取数据 var lib3 = obj.library[3]; //动漫角色资料接口 var lib4 = obj.library[4]; //获取随机库中番组 var url = obj.mainUrl + lib.Url + lib.parameter; var url1 = obj.mainUrl + lib1.Url + lib1.parameter + name + lib1.parameter1; var url2 = obj.mainUrl + lib2.Url + lib2.parameter + name + lib2.parameter1[0] + + lib2.parameter1[1]; var url3 = obj.mainUrl + lib3.Url + lib3.parameter; var url4 = obj.mainUrl + lib4.Url + lib4.parameter + lib4.parameter; console.log("url",url,"url1",url1,"url2",url2,"url3",url3,"url4",url4); var jsData; if(apiId == 0){ jsData = await getResourceByURL(url,true); //获取随机库中台词 }else if(apiId == 1){ jsData = await getResourceByURL(url1,true); //根据库ID获取台词 }else if(apiId == 2){ jsData = await getResourceByURL(url2,true); //根据作品名获取数据 }else if(apiId == 3){ jsData = await getResourceByURL(url3,true); //动漫角色资料接口 }else if(apiId == 4){ jsData = await getResourceByURL(url4,true); //获取随机库中番组 } console.log("数据获取成果",jsData); return jsData; break; default: break; }//switch } } //------------------------------------------------------------------------------------------------------------- class SteamDB { constructor(){ this.mainURL = "https://steamdb.info/"; this.freeGameURL = "upcoming/free/"; } async initUI(gameInfo){ //初始化UI // jQuery(".friends_header_ctn").after( // '<div id="GameFreeInfo">\ // <div id="add1_head">喜加一</div>\ // <div id="add1_body" style="display:inline-block;width:100%;overflow: hidden;white-space: nowrap;text-overflow: ellipsis; /*超出部分用...代替*/">\ // </div>\ // <div id="limitedTime_head">限时免费</div>\ // <div id="limitedTime_body" style="display:inline-block;width:100%;overflow: hidden;white-space: nowrap;text-overflow: ellipsis; /*超出部分用...代替*/">\ // </div>\ // <div id="prediction_head">预告</div>\ // <div id="prediction_body" style="display:inline-block;width:100%;overflow: hidden;white-space: nowrap;text-overflow: ellipsis; /*超出部分用...代替*/">\ // </div>\ // </div>' // ); console.log("initUI success!"); } async GameFreeInfoHelper(){ //游戏免费信息助手 console.log("GameFreeInfoHelper call..."); initUI(data); //初始化UI console.log("GameFreeInfoHelper success!"); } async getFreeGameInfo(){ //获取游戏喜加一信息(SteamDB) var url = this.mainURL + this.freeGameURL; var jsData = await getResourceByURL(url,true); // console.log("数据获取成果",jsData); } async getGameDiscountsInfoBysteamDB(){ //获取游戏折扣信息(SteamDB,HB,F站...) const url_fanatical = "https://www.fanatical.com/"; const url_humblebundle = "https://www.humblebundle.com/"; const url_indiegala = "http://indiegala.com/"; const url_steam = "https://store.steampowered.com/search/?filter=topsellers&specials=1"; } } //------------------------------------------------------------------------------------------------------------- //1.请求 http://www.sonkwo.hk/store/search?keyword=GameName,手动解析数据 //------------------------------------------------------------------------------------------------------------- //Fanatical (慢速警告) //1.请求 https://www.fanatical.com/zh-hans/search?search=GameName,手动解析数据 //------------------------------------------------------------------------------------------------------------- //humblebundle (慢速警告) //1.请求 https://www.humblebundle.com/store/search?sort=bestselling&search=GameName,手动解析数据 //------------------------------------------------------------------------------------------------------------- //1.请求 https://www.ccyyshop.com/bundles,手动解析数据 //------------------------------------------------------------------------------------------------------------- //第三方网站抓取,比如 https://isthereanydeal.com/ajax/game/info?plain=nierautomata /** * steamApis.js */ //------------------------------------------------------------------------------------------------------------- // steam api function setRemarks(profileID, remarkName) { var URL = "https://steamcommunity.com/profiles/" + profileID + "/ajaxsetnickname/"; jQuery.post(URL, { nickname: remarkName, sessionid: g_sessionID }, function(response) { if (response.success === false) { console.log("设置备注失败了!"); } else { console.log("成功设置备注于"); } }).fail(function() { console.log("无法设置备注于"); }).always(function() { //console.log("当前处理了 " + (i + 1) + "个, 总计 " + total + " 个好友."); }); } class ConfirmDialog { static open(strTitle, strDescription, strOKButton, strCancelButton, strSecondaryActionButton) { return ExtensionLayer.runInPageContext((a,b,c,d,e) => { let prompt = ShowConfirmDialog(a,b,c,d,e); return new Promise((resolve, reject) => { prompt.done(result => { resolve(result); }).fail(() => { resolve("CANCEL"); }); }); }, [ strTitle, strDescription, strOKButton, strCancelButton, strSecondaryActionButton ], true); } } // ConfirmDialog.open("TEST"); //------------------------------------------------------------------------------------------------------------- function getUserLocation(profileID) //获取用户位置() { var name = document.getElementsByClassName("header_real_name ellipsis")[0].getElementsByTagName("bdi")[0].innerText; var str = document.getElementsByClassName("header_real_name ellipsis")[0].innerText; var index = str.indexOf(name); var strLocation = ""; var arrLocation = []; if( index != -1) { strLocation = str.slice(index+name.length); //裁剪,获取地址位置字符串 strLocation = strLocation.replace(/\s+/g,""); //去除所有的空格 if(strLocation == "") { return null; //没有获取到数据 } arrLocation = strLocation.split(','); } console.log("arrLocation",arrLocation); for (let i = arrLocation.length-1; i >= 0; i--) { console.log(arrLocation[i]); return arrLocation; } } // var ret = getUserLocation(); // if(ret != null) // { // if(ret>1) // { // getCityChinsesNameByEnglishName(ret[0]); // } // } function getUserCommentData(profileID) //获取用户的评论的大数据(用户64位id) { var date = new Date(); jQuery.post("//steamcommunity.com/comment/Profile/post/" + profileID + "/-1/", { comment: newMgs, count: 6, sessionid: g_sessionID }, function(response) { if (response.success === false) { jQuery("#log_body")[0].innerHTML += "<a style='color:#ff2c85;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 留言失败了! ' + profileID + ' ' + name + ' ' + response.error + "</a><br>"; } else { jQuery("#log_body")[0].innerHTML += '[' + (i + 1) + '/' + total + '] ' + "成功发表评论于 <a target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a>" + "<span> → </span><a style='color:#FB7299;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + newMgs + "</a><br>"; } }).fail(function() { jQuery("#log_body")[0].innerHTML += '[' + (i + 1) + '/' + total + '] ' + "<span style='color:#DA2626;'>无法发表评论于 <a style='color:#DA2626;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a></span><br>"; }).always(function() { jQuery("#log_head").html("<br><b>当前处理了 " + (i + 1) + "个, 总计 " + total + " 个好友.<b>"); }); } function setSaveUserCommentData(profileID,str) //设置已保存的用户评论数据 { } function getSaveUserCommentData(profileID) //获取已保存的用户评论数据 { } // var jqobj; // function traverseAllFriend() //遍历所有好友 // { // function concurrentPoll() { // this.tasks = []; // 任务队列 // this.max = 100; // 最大并发数 // setTimeout(() => { // 函数主体执行完后立即执行 // this.run() // }, 0); // } // concurrentPoll.prototype.addTask = function(task) { // 原型添加任务方法 // this.tasks.push(task) // } // concurrentPoll.prototype.run = function() { // 原型任务运行方法 // if (this.tasks.length == 0) { // 判断是否还有任务 // return // } // var min = Math.min(this.tasks.length, this.max); // 取任务个数与最大并发数最小值 // for (var i = 0; i < min; i++) { // this.max--; // 执行最大并发递减 // var task = this.tasks.shift(); // 从数组头部取任务 // task().then((res) => { // 重:此时可理解为,当for循环执行完毕后异步请求执行回调,此时max变为0 // console.log(res) // }).catch((err) => { // console.log(err) // }).finally(() => { // 重:当所有请求完成并返回结果后,执行finally回调,此回调将按照for循环依次执行,此时max为0. // this.max++; // 超过最大并发10以后的任务将按照任务顺序依次执行。此处可理解为递归操作。 // this.run(); // }) // } // } // var poll = new concurrentPoll(); // 实例 // //并发多个相同任务 // jqobj = jQuery(".selectable[data-steamid]"); //选择所有好友 // //for (let i = 0; i < jqobj.length; i++) { // for (let i = 0; i < 1; i++) { // let cur = jqobj.get(i); // let profileID = cur.getAttribute("data-steamid"); // poll.addTask(function() { // return new Promise( // function(resolve, reject) { // // 一段耗时的异步操作 // getProfilesInfo(resolve, reject, i, profileID); // }) // }) // } // console.log("完毕!"); // // for (let i=0; i<23; i++) { // 数据模拟 // // poll.addTask(function () { // // return new Promise( // // function (resolve, reject) { // // // 一段耗时的异步操作 // // getProfilesInfo(resolve, reject,i,"76561198818854009"); // // })}) // // } // // poll.addTask(async function () { // // //let arr = [fun(0),fun(1),fun(2)]; // // let arr = []; // // for (var i=0; i<13; i++) { // 数据模拟 // // //arr.push(fun(i)); // // arr.push(new Promise(function (resolve, reject){getProfilesInfo(i,"76561198818854009");})); // // } // // let res = await Promise.all(arr); // // return res; // // // new Promise( // // // function (resolve, reject) { // // // // 一段耗时的异步操作 // // // getProfilesInfo("76561198818854009"); // // // resolve('成功') // 数据处理完成 // // // // reject('失败') // 数据处理出错 // // // }) // // }) // } // var waitStatus1 = []; //等待状态 // var returnData1 = []; //返回数据 // async function getgetProfilesID(i, profileID) { // let URL = "https://steamcommunity.com/profiles/" + profileID + "/"; // if (waitStatus1.length == 0) // waitStatus1.length = jqobj.length; //设置数组长度 // if (returnData1.length == 0) // returnData1.length = jqobj.length; //设置数组长度 // //waitStatus1.push([profileID,true]); //开始等待 // waitStatus1[i] = [profileID, true]; //存储数据到对应的位置(受网络影响,响应顺序可能会不同) // //console.log("getgetProfilesID() i:",i,"waitStatus1:",waitStatus1); // jQuery.ajax({ // type: "Get", //请求方式 // //async: false, // //contentType: "application/json;charset=UTF-8",//请求的媒体类型 // url: URL, //请求地址 // // headers: { // // 'User-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.122 Safari/537.36', // // //'Accept': 'application/atom+xml,application/xml,text/xml', // // //"Content-Type": "application/x-www-form-urlencoded", // // }, // //data: JSON.stringify(list), //数据,json字符串 // success: function(result) { //请求成功 // let Data = result; // //console.log("请求成功了!",Data); // let nIstart = Data.indexOf('StartTradeOffer('); // let nIend = Data.indexOf(');', nIstart); // let AccountID = Data.slice(nIstart + 'StartTradeOffer('.length + 1, nIend - 1); // nIstart = Data.indexOf('"steamid":"'); // nIend = Data.indexOf('",', nIstart); // let profileID = Data.slice(nIstart + '"steamid":"'.length, nIend); // console.log("getgetProfilesID() i:", i, "AccountID:", AccountID, "profileID:", profileID); // for (let i = 0; i < waitStatus1.length; i++) { // if (waitStatus1[i][0] == profileID) //是否是同一个用户 // { // if (waitStatus1[i][1] == false) //这个用户是否已经获取过了(测试多个相同用户信息的获取) // continue; // waitStatus1[i][1] = false; // //returnData1.push(AccountID); //存储数据 // returnData1[i] = AccountID; //存储数据到对应的位置(受网络影响,响应顺序可能会不同) // //console.log("getgetProfilesID() 成功存储数据 AccountID:",AccountID); // return; // //console.log("waitStatus1[i][1] break",i,waitStatus1[i][1]); // } // } // console.log("getgetProfilesID 数据错误!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"); // console.log("waitStatus1:", waitStatus1, 'returnData1:', returnData1); // console.log('profileID:', profileID, 'AccountID:', AccountID); // return; // //console.log("DBG!",nIstart,nIend); // }, // error: function(e) { //请求失败,包含具体的错误信息 // console.log("请求失败了!", e.status); // console.log("请求失败了!", e.responseText); // } // }); // //console.log("getgetProfilesID() i:",i,"waitStatus1:",waitStatus1); // while (waitStatus1[i][1]) //强制等待异步函数执行完毕后再执行 // { // //console.log("wait...",i,waitStatus1[i][1]); // await sleep(50); //延迟0.1秒 // } // //console.log("waitStatus1[i][1]:",waitStatus1[i][1],"returnData1[i]:",returnData1[i]); // return returnData1[i]; // // jQuery.get(URL, { // // // "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9", // // // // "Content-Type": "application/x-www-form-urlencoded", //非常重要 // // // "Accept-Encoding": "gzip, deflate, br", // // // "Accept-Language": "zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2", // // // "Cache-Control": "max-age=0", // // // "Connection": "keep-alive", // // // "Cookie": "sessionid=6f84a0f48cddb56ad66394b6; steamCountry=HK%7Cda7daa2682f7a361e594f8dad55fe9df; timezoneOffset=28800,0", // // // "Host": "steamcommunity.com", // // // "Upgrade-Insecure-Requests": "1", // // 'User-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.122 Safari/537.36', // // }, function(response) { // // if (response.status === 200) { // // console.log("获取失败!",response.responseText); // // } else { // // console.log("获取成功!",response.responseText); // // } // // }).fail(function() { // // console.log("无法获取!"); // // }).always(function() { // // //console.log("当前处理了 " + (i + 1) + "个, 总计 " + total + " 个好友."); // // }); // // GM_xmlhttpRequest({ // // method: 'GET', // // url: URL, // // headers: { // // 'User-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.122 Safari/537.36', // // //'Accept': 'application/atom+xml,application/xml,text/xml', // // //"Content-Type": "application/x-www-form-urlencoded", // // }, // // onload: function(response) { // // if (response.status === 200) { // // console.log('请求成功!',response.responseText); // // //var JSON_jsObj = JSON_processing_parsing_JsObj(response.responseText); // // //遍历[0][0]数组就可以取得翻译后的文本,原始数据,原始数据的拼音 // // //[2]是检查出的语言 // // //遍历[5]可以取得两种翻译,原始数据和原始数据的长度 // // //遍历[8]可以得到原始语言和翻译语言 // // //for (var i = 0; i < JSON_jsObj.length; i++) { // // // for (var j = 0; j < JSON_jsObj[i].length; j++) { // // // for (var k = 0; k < JSON_jsObj[i][j].length; k++) { // // // // // // } // // // } // // //} // // //var retData = ""; // // //for (var j = 0; j < JSON_jsObj[0].length; j++) { // // // if (JSON_jsObj[0][j][0] != null) { // // // retData += JSON_jsObj[0][j][0]; //组合每一句翻译 // // // } // // //} // // returnData = retData; //存储数据 // // //console.log('谷歌翻译:',retData); // // waitStatus = false; //不等待 // // //console.log(response); // // //console.log(response.responseText); // // //if(response.responseText.indexOf('[[["') == 0) //是否是指定的数据格式 // // //{ // // // var retData = response.responseText.slice(4,response.responseText.indexOf('","',4)); //提取翻译后的文本 // // // returnData = retData; //存储数据 // // // //console.log('谷歌翻译:',retData); // // // waitStatus = false; //不等待 // // //} // // } else { // // console.log('请求失败!'); // // //console.log(response); // // //console.log(response.responseText); // // } // // }, // // onerror: function(err) { // // console.log('请求错误!', err); // // } // // }); // } // var waitStatus = []; //等待状态 // var returnData = []; //返回数据 // async function getProfilesInfo(resolve, reject, i, profileID) { // let joinDate, friendDate; // let str; // if (waitStatus.length == 0) // waitStatus.length = jqobj.length; //设置数组长度 // if (returnData.length == 0) // returnData.length = jqobj.length; //设置数组长度 // jQuery.ajaxSetup({ // cache: false // }); //close AJAX cache // ////获取一个数组真实长度 // //let arrRealLength = undefined; // //for (let i = 0; i < waitStatus.length; i++) { // // if(waitStatus[i] == undefined) // // { // // arrRealLength = i; // // break; // // } // //} // //if(arrRealLength == undefined) //是否为数组最大长度 // // arrRealLength = waitStatus.length; // //waitStatus.push([profileID,true]); //开始等待 // waitStatus[i] = [profileID, true]; //存储数据到对应的位置(受网络影响,响应顺序可能会不同) // await getgetProfilesID(i, profileID); // // let AccountID = returnData1[i]; // //console.log("getProfilesInfo(): AccountID:",AccountID,'i:',i,"returnData[i]:",returnData[i]); // //var AccountID = "242752742";//242752742//858588281 // let URL = "https://steamcommunity.com/tradeoffer/new/?partner=" + AccountID; // jQuery.ajax({ // type: "Get", //请求方式 // //async: false, // //contentType: "application/json;charset=UTF-8",//请求的媒体类型 // url: URL, //请求地址 // // headers: { // // 'User-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.122 Safari/537.36', // // //'Accept': 'application/atom+xml,application/xml,text/xml', // // //"Content-Type": "application/x-www-form-urlencoded", // // }, // //data: JSON.stringify(list), //数据,json字符串 // success: function(result) { //请求成功 // let Data = result; // if (Data.indexOf("抱歉,发生了某种错误:") != -1) //不能正常进行交易,获取不到数据就跳过 // { // waitStatus[i][1] = false; // returnData[i] = null; //不返回数据 // return; // } // //console.log("请求成功了!",Data); // let nIstart = Data.indexOf('trade_partner_member_since trade_partner_info_text'); // if (nIstart == -1) { // nIstart = Data.indexOf('trade_partner_header responsive_trade_offersection top'); // let nindex = Data.indexOf('trade_partner_info_text">', nIstart); // let nIend = Data.indexOf('</div>', nindex); // friendDate = Data.slice(nindex + 'trade_partner_info_text">'.length, nIend); //加入Steam的日期 // friendDate = friendDate.replace(/^\s+|\s+$/g, ""); //去除左右两边的空格 // joinDate = "查询不到"; // nIstart = Data.lastIndexOf('g_ulTradePartnerSteamID'); // nIindex = Data.indexOf('\'', nIstart); // nIend = Data.indexOf('\'', nIindex + 1); // profileID = Data.slice(nIindex + 1, nIend); // //console.log("profileID",profileID); // } else { // let nIindex = Data.indexOf('>', nIstart); // let nIend = Data.indexOf('</div>', nIindex); // joinDate = Data.slice(nIindex + 1, nIend); //加入Steam的日期 // //console.log("joinDate",joinDate); // nIstart = Data.indexOf('trade_partner_info_text'); // nIindex = Data.indexOf('>', nIstart); // nIend = Data.indexOf('</div>', nIindex); // friendDate = Data.slice(nIindex + 1, nIend - 1); //成为好友的日期 // friendDate = friendDate.replace(/^\s+|\s+$/g, ""); //去除左右两边的空格 // //console.log("friendDate",friendDate); // nIstart = Data.lastIndexOf('g_ulTradePartnerSteamID'); // nIindex = Data.indexOf('\'', nIstart); // nIend = Data.indexOf('\'', nIindex + 1); // profileID = Data.slice(nIindex + 1, nIend); // //console.log("profileID",profileID); // } // for (let i = 0; i < waitStatus.length; i++) { // if (waitStatus[i][0] == profileID) //是否是同一个用户 // { // if (waitStatus[i][1] == false) //这个用户是否已经获取过了(测试多个相同用户信息的获取) // continue; // waitStatus[i][1] = false; // //returnData.push([joinDate,friendDate]); //存储数据 // returnData[i] = [joinDate, friendDate]; //存储数据到对应的位置(受网络影响,响应顺序可能会不同) // //console.log("waitStatus[i][1] break",i,waitStatus[i][1]); // return; // } // } // console.log("getProfilesInfo 数据错误!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"); // console.log("waitStatus:", waitStatus, "returnData:", returnData); // console.log("profileID", profileID); // //console.log("Data",Data); // return; // //console.log("DBG!",nIstart,nIend); // }, // error: function(e) { //请求失败,包含具体的错误信息 // console.log("请求失败了!", e.status); // console.log("请求失败了!", e.responseText); // } // }); // while (waitStatus[i][1]) //强制等待异步函数执行完毕后再执行 // { // //console.log("wait...",i,waitStatus[i][1]); // await sleep(50); //延迟0.1秒 // } // if (returnData[i] == null) //检查数据有效性 // { // console.log("str [" + (i + 1) + "] 不能获取到数据,已跳过: https://steamcommunity.com/profiles/" + profileID); // return; // } // console.log("waitStatus[i][1]:", waitStatus[i][1], "waitStatus[i]:", waitStatus[i]); // str = "加入日期: " + returnData[i][0] + " 成为好友日期: " + returnData[i][1]; // console.log("str [" + (i + 1) + ']', str); // resolve('成功') // 数据处理完成 // // reject('失败') // 数据处理出错 // return str; // } // // let arr = []; // // for (var i=0; i<1; i++) { // 数据模拟 // // //arr.push(fun(i)); // // arr.push(new Promise(function (resolve, reject){getProfilesInfo(1,2,i,"76561198818854009");})); // // } // // let res = await Promise.all(arr); // // var jqobj = jQuery(".selectable[data-steamid]"); //选择所有好友 // // let arr = []; // // for (var i=0; i<20; i++) { // 数据模拟 // // let cur = jqobj.get(i); // // let profileID = cur.getAttribute("data-steamid"); // // //arr.push(fun(i)); // // //getProfilesInfo(1, 2,i,profileID); // // arr.push(new Promise(function (resolve, reject){getProfilesInfo(1, 2,i,profileID);})); // // } // // let res = await Promise.all(arr); //------------------------------------------------------------------------------------------------------------------------------------------ //miku-39 class friendActivity{ constructor(profileID_Url) { /*构造方法(用户id或者自定义链接)*/ this.steamCommunityUrl = "https://steamcommunity.com/"; this.customUrl = "id/"; this.profileIDUrl = "profiles/"; this.friendActivitUrl = "/home"; this.friendActivitOptionUrl = "/blotteredit"; this.startElementsId = "blotter_content"; this.endElementsId = "blotter_throbber"; this.jsName = "g_BlotterNextLoadURL"; this.friendActivityElementsBlockId = "blotter_block"; this.isYun = false; //游戏评测 this.UserEvaluationUp = "UserReviewVoteUp"; //用户评价 是 的函数名 this.UserEvaluationDown = "UserReviewVoteDown"; //用户评价 否 的函数名 this.UserEvaluationHappy = "UserReviewVoteTag"; //用户评价 欢乐 的函数名 //上传载图、收藏载图 //指南添加到收藏夹、发表指南 //艺术作品添加到收藏夹、发布艺术作品 //添加视频、收藏视频 this.captureUp = "VoteUp"; //用户评价 赞 的函数名 this.captureDown = "VoteDown"; //用户评价 否 的函数名 this.captureShare = "ShowSharePublishedFilePopup"; //用户操作 分享 的函数名 //购买游戏或者DLC this.bus = "VoteUpCommentThread"; //用户评价 赞 的函数名 "VoteUpCommentThread('UserReceivedNewGame" //发布状态或者游戏状态 this.status = "VoteUpCommentThread"; //用户评价 赞 的函数名 "VoteUpCommentThread('UserStatusPublished" this.groupNotificationUp = "RateAnnouncement"; //用户评价 赞 this.groupNotificationDown = "RateAnnouncement"; //用户评价 否 this.g_bRecoredUpvote = false; //制作一件物品时 ghs 强烈推荐 发布艺术作品之类的 //在某人的截图中? 发布艺术作品之类的,状态等 //jQuery(".ugc.has_adult_content img, .ugc.has_adult_content div.imgWallItem") //var obj = jQuery(".ugc.has_adult_content img, .ugc.has_adult_content div.imgWallItem"); //for (let i = 0; i < obj.length; i++) { // obj[i].style.filter = "none"; // obj[i].style.border = "2px red solid"; // obj[i].parentNode.parentNode.parentNode.parentNode.style.border = "2px red solid"; //} if(isIntNum(profileID_Url)){ this.profileID_Url = profileID_Url.toString(); //用户id this.mode = 0; this.Url = this.steamCommunityUrl + this.profileIDUrl + this.profileID_Url; } else{ this.profileID_Url = profileID_Url; //自定义链接 this.mode = 1; this.Url = this.steamCommunityUrl + this.customUrl + this.profileID_Url; } } async init(profileID_Url){ if(isIntNum(profileID_Url)){ this.profileID_Url = profileID_Url.toString(); //用户id this.mode = 0; this.Url = this.steamCommunityUrl + this.profileIDUrl + this.profileID_Url; } else{ this.profileID_Url = profileID_Url; //自定义链接 this.mode = 1; this.Url = this.steamCommunityUrl + this.customUrl + this.profileID_Url; } } LogUpvote(){ if ( !this.g_bRecoredUpvote ) { this.g_bRecoredUpvote = true; $J.post( 'https://steamcommunity.com/actions/LogFriendActivityUpvote', {sessionID: g_sessionID} ); } } VoteUp(item_id){ //有些东西点不了赞 var options = { method: 'post', postBody: 'id=' + item_id + '&sessionid=' + g_sessionID, onComplete: (function(item_id){ return function(transport) { var response = JSON.parse(transport.responseText); switch (response.success){ case 1: //debugger //console.log("VoteUp() 已经点过赞了!",transport.responseText); break; case 10: //debugger //console.log("VoteUp() 点赞完成??",transport.responseText); break; case 15: //debugger console.log("VoteUp() 点赞错误!!!",transport.responseText); break; default: //{"success":20} //{"success":16,"items":[2082593203],"results":{"2082593203":16}} debugger console.log("VoteUp() ????????????????????????????????????????????????????????????",transport.responseText); break; } } }(item_id)) }; new Ajax.Request( 'https://steamcommunity.com/sharedfiles/voteup', options ); this.LogUpvote(); } //home页面 InitializeCommentThread //rgCommentData['pagesize'] //var CCommentThread = Class.create //initialize: function( type, name, rgCommentData, url, nQuoteBoxHeight ) //function InitializeCommentThread( type, name, rgCommentData, url, nQuoteBoxHeight ) //this.m_cPageSize VoteUpCommentThread(commentthreadid){ //这个函数有不确定性 let iprefix = commentthreadid.indexOf('_'); var prefixUrl = commentthreadid.slice(0,iprefix); let iowner = commentthreadid.indexOf('_',iprefix+1); var ownerUrl = commentthreadid.slice(iprefix+1,iowner); var featureUrl = commentthreadid.slice(iowner+1); this.LogUpvote(); var GetActionURL = function(action){ var url = "https://steamcommunity.com/comment/" + prefixUrl + "/" + action + "/"; url += ownerUrl + '/'; url += featureUrl + '/'; return url; } var countValue = 3; switch (prefixUrl){ case 'UserReceivedNewGame': //购买游戏或者DLC countValue = 3; break; case 'PublishedFile_Public': //没有测试过是否有这个 debugger countValue = 3; break; case 'UserStatusPublished': //发布状态或者游戏状态 countValue = 6; break; default: debugger console.log("VoteUpCommentThread() ??????????????????????????????????????????????????"); break; } var params = { vote: 1, count: countValue, sessionid: g_sessionID, feature2: -1, newestfirstpagination: true, }; new Ajax.Request( GetActionURL( 'voteup' ), { method: 'post', parameters: params, onSuccess: ()=>{ //console.log("VoteUpCommentThread() 点赞成功!",countValue,commentthreadid) }, onFailure: ()=>{ console.log("VoteUpCommentThread() 点赞失败! 与网络通信时出错。请稍后再试。",countValue,commentthreadid) }, onComplete: ()=>{ //console.log("VoteUpCommentThread() 点赞完毕! 用时",countValue,commentthreadid) } } ); } UserReviewVoteUp(id) { //debugger this.UserReview_Rate( id, true, 'https://steamcommunity.com', function( rgResults,recommendationID ) { //console.log("UserReviewVoteUp() 点赞成功~",rgResults,recommendationID); } ); } UserReview_Rate(recommendationID, bRateUp, baseURL, callback) { $J.post( baseURL + '/userreviews/rate/' + recommendationID,{ 'rateup' : bRateUp, 'sessionid' : g_sessionID }).done( function( results,recommendationID ) { if ( results.success == 1 ) { callback( results ); } else if ( results.success == 21 ) { ShowAlertDialog( '错误', '您必须先登录以执行该操作。' ); } else if ( results.success == 15 ) { ShowAlertDialog( '错误', '您的帐户没有足够的权限执行此操作。' ); } else if ( results.success == 24 ) { ShowAlertDialog( '错误', '您的帐户不符合使用该功能的要求。<a class="whiteLink" href="https://help.steampowered.com/zh-cn/wizard/HelpWithLimitedAccount" target="_blank" rel="noreferrer">访问 Steam 客服</a>了解更多信息。' ); } else { ShowAlertDialog( '错误', '在尝试处理您的请求的过程中出现了错误:' + results.success ); } } ); } RateAnnouncement(strArguments){ //解析参数并填充 var rateURL, gid, bVoteUp, clanID; strArguments = strArguments.replace(/'/g, ""); //去除字符串中出现的所有单引号 strArguments = strArguments.replace(/\s+/g,""); //去除字符串所有的空格 var arr = strArguments.split(','); //划分为参数 rateURL = arr[0]; gid = arr[1]; if(arr[2]=="true") bVoteUp = true; else bVoteUp = false; clanID = parseInt(arr[3]); rateURL = rateURL + gid; $J.post( rateURL, { 'voteup' : bVoteUp, 'clanid' : clanID, 'sessionid' : g_sessionID } ).done( function( json ) { //console.log("RateAnnouncement() 点赞成功.",json); } ) .fail( function( jqxhr ) { var responseJSON = jqxhr.responseText.evalJSON(); switch ( responseJSON.success ) { case 21: ShowAlertDialog( '错误', '您必须登录才能执行该操作。' ); break; case 24: ShowAlertDialog( '错误', '您的帐户不符合使用该功能的要求。<a class="whiteLink" href="https://help.steampowered.com/zh-cn/wizard/HelpWithLimitedAccount" target="_blank" rel="noreferrer">访问 Steam 客服</a>了解更多信息。' ); break; case 15: ShowAlertDialog( '错误', '您没有执行该操作的权限。' ); break; default: ShowAlertDialog( '错误', '在处理您的请求时遇到错误:' + responseJSON.success ); break; } } ); return false; } //g_BlotterNextLoadURL //StartLoadingBlotter( g_BlotterNextLoadURL ); async Run(){ //开始点赞 var documentData; var arrData; var nextLoadURL; var url = this.Url + this.friendActivitUrl; this.isYun = true; console.log("开始点赞...",url); var i = 0; while(this.isYun) { i++; if(i==1){ documentData = await getResourceByURL(url,true); //console.log("url:",this.Url,"data:",documentData); var index = documentData.indexOf(this.startElementsId); //开始区域 blotter_content var endindex = documentData.lastIndexOf(this.endElementsId); //结束区域 blotter_throbber var Data = documentData.slice(index,endindex); var jsindex = documentData.indexOf(this.jsName,endindex); var jsendindex = documentData.indexOf(';',jsindex); var jsData = documentData.slice(jsindex,jsendindex); nextLoadURL = jsData.slice(jsData.indexOf('\'')+1,jsData.lastIndexOf('\'')); //console.log("Data:",Data,"nextLoadURL:",nextLoadURL); arrData = Data.split(this.friendActivityElementsBlockId); } //else if ( !response ){ // // print out any error for now 现在打印出任何错误 // console.log("错误:",transport.responseText); // //$('blotter_content').insert( { bottom: transport.responseText } ); //} else { documentData = await getResourceByURL(url,false); //获取原始数据 //console.log("url:",this.Url,"data:",documentData); //console.log(documentData); this.g_bRecoredUpvote = false; // load more data //var response = documentData.responseJSON; if(documentData.responseText == undefined){ //针对请求失败的情况(自实现) console.log("请求失败,错误码: 0x1 潜在的网络故障 url:"+ url); debugger var index = url.lastIndexOf('='); nextLoadURL = url.slice(0,index); //提取最前面的链接 var num = parseInt(url.slice(index+1));s nextLoadURL += (num+250); url = nextLoadURL; continue; } console.log("documentData.responseText",documentData.responseText); var response = JSON.parse(documentData.responseText); if ( response && response.success == true && response.blotter_html ){ // append the new day, having it fade in quickly 补充新的一天,让它迅速消失 // Scan each blotter response for an event ID we've seen before, so we can prune them out 扫描每个吸纸器响应以获取我们之前见过的事件ID,以便我们将其删节 var html = response.blotter_html; arrData = html.split(this.friendActivityElementsBlockId); //var newDiv = new Element ( 'div' ); //newDiv.update( html ); //newDiv.setOpacity(0); //$('blotter_content').appendChild( newDiv ); //Blotter_RecordAppImpressions(); //ApplyAdultContentPreferences(); //new Effect.Appear( newDiv, { duration: .75 } ); //g_BlotterNextLoadURL = response.next_request; nextLoadURL = response.next_request; //debugger //Blotter_InfiniteScrollingCheckForMoreContent(); //Blotter_AddHighlightSliders(); } else { //针对请求失败的情况(自实现) console.log("请求失败,错误码: 0x2 请求错误 url:"+ url); debugger var index = url.lastIndexOf('='); nextLoadURL = url.slice(0,index); //提取最前面的链接 var num = parseInt(url.slice(index+1));s nextLoadURL += (num+250); url = nextLoadURL; continue; } } // debugger for (let i = 0; i < arrData.length; i++) { //console.log(arrData[i]); var k = arrData[i].lastIndexOf(this.bus); //VoteUpCommentThread('UserReceivedNewGame if(k>0) { var startk = arrData[i].indexOf('(',k); var endk = arrData[i].indexOf(')',startk); var code = arrData[i].slice(startk+1,endk); code = code.replace(/'/g, ""); //去除字符串中出现的所有单引号 code = code.replace(/^\s*|\s*$/g,""); //去除字符串内两头的空格 //console.log("code",code); //debugger this.VoteUpCommentThread(code); //点赞 await sleep(50); //延迟0.01秒 continue; } // var l = arrData[i].lastIndexOf(this.status); //VoteUpCommentThread('UserStatusPublished // if(l>0) // { // var startl = arrData[i].indexOf('(',l); // var endl = arrData[i].indexOf(')',startl); // var code = arrData[i].slice(startl+1,endl); // code = code.replace(/'/g, ""); //去除字符串中出现的所有单引号 // code = code.replace(/^\s*|\s*$/g,""); //去除字符串内两头的空格 // console.log("code",code); // debugger // this.VoteUpCommentThread(code); //点赞 // await sleep(50); //延迟0.01秒 // continue; // } var o = arrData[i].lastIndexOf(this.UserEvaluationUp); //UserReviewVoteUp if(o>0) { var starto = arrData[i].indexOf('(',o); var endo = arrData[i].indexOf(')',starto); var code = arrData[i].slice(starto+1,endo); code = code.replace(/'/g, ""); //去除字符串中出现的所有单引号 code = code.replace(/^\s*|\s*$/g,""); //去除字符串内两头的空格 //debugger ////console.log("code",code); this.UserReviewVoteUp(code); //点赞 await sleep(50); //延迟0.01秒 continue; } var j = arrData[i].indexOf(this.captureUp); //VoteUp if(j>0) { var startj = arrData[i].indexOf('(',j); var endj = arrData[i].indexOf(')',startj); var code = arrData[i].slice(startj+1,endj); //console.log("code",code); //debugger if(code.indexOf(',') == -1) //如果不是组点赞则继续点赞,否则继续往后面执行 { this.VoteUp(parseInt(code)); //点赞 await sleep(50); //延迟0.01秒 continue; } } var getCode = (m)=>{ var startm = arrData[i].indexOf('(',m); var endm = arrData[i].indexOf(')',startm); var code = arrData[i].slice(startm+1,endm); ////console.log("code",code); var iId = arrData[i].indexOf('id',endm); var startId = arrData[i].indexOf('"',iId); var endId = arrData[i].indexOf('"',startId+1); var idValue = arrData[i].slice(startId+1,endId); //console.log("idValue",idValue); if(idValue.indexOf('Up') != -1){ return [true,code]; } else if(idValue.indexOf('Down') != -1){ return [false,code]; } else{ console.log("组点赞出错!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"); } } var m = arrData[i].indexOf(this.groupNotificationUp); //RateAnnouncement if(m>0) { //查找设置 var ret = getCode(m); //debugger if(ret[0]==true){ this.RateAnnouncement(ret[1]); //点赞 await sleep(50); //延迟0.01秒 } else{ this.RateAnnouncement(ret[1]); //踩 await sleep(50); //延迟0.01秒 } continue; } } //debugger url = nextLoadURL; //console.log(url,"点赞完毕! 加载下一个url:", nextLoadURL); var index = url.indexOf("?start=")+1; var endindex = url.indexOf("&",index); if(endindex == -1) endindex = url.length; var time = url.slice(index + "?start".length,endindex); time = parseInt(time); var date = new Date(time*1000); var year = date.getFullYear(); var mon = date.getMonth()+1; var day = date.getDate(); var hours = date.getHours(); var minu = date.getMinutes(); var sec = date.getSeconds(); //if(mon<10) mon = "0"+mon; //if(day<10) day = "0"+day; //if(hours<10) hours = "0"+hours; //if(minu<10) minu = "0"+minu; //if(sec<10) sec = "0"+sec; var str = year+'-'+mon+'-'+day+' '+hours+':'+minu+':'+sec; //year+"年"+mon+"月"+day +"日"+hours +"时"+minu +"分"+sec+"秒" //date.toLocaleString() console.log(url,"点赞完毕! 下一次点赞的内容时间是:", str + " startoffset:",url.slice(url.lastIndexOf("startoffset=") + "startoffset=".length)); } //while var time = url.slice(url.indexOf("=")+1); time = parseInt(time); var date = new Date(time*1000); var year = date.getFullYear(); var mon = date.getMonth()+1; var day = date.getDate(); var hours = date.getHours(); var minu = date.getMinutes(); var sec = date.getSeconds(); var str = year+'-'+mon+'-'+day+' '+hours+':'+minu+':'+sec; console.log("点赞完毕! 已将"+ str +"这个时间线之后的动态全部点赞完毕!~"); } Stop(){ console.log("开始停止点赞..."); this.isYun = false; } async setfriendActivityOption(){ var url = this.Url + this.friendActivitOptionUrl; jQuery.post(url, { setting: 1, sessionid: g_sessionID, "subscription_option[friendadded]": 1, "subscriptions[friendadded]": 1, "subscription_option[achievementunlocked]": 1, "subscriptions[achievementunlocked]": 1, "subscription_option[receivednewgame]": 1, "subscriptions[receivednewgame]": 1, "subscription_option[joinedgroup]": 1, "subscriptions[joinedgroup]": 1, "subscription_option[createsgroup]": 1, "subscriptions[createsgroup]": 1, "subscription_option[addedgametowishlist]": 1, "subscriptions[addedgametowishlist]": 1, "subscription_option[recommendedgame]": 1, "subscriptions[recommendedgame]": 1, "subscription_option[screenshotpublished]": 1, "subscriptions[screenshotpublished]": 1, "subscription_option[videopublished]": 1, "subscriptions[videopublished]": 1, "subscription_option[filefavorited]": 1, "subscriptions[filefavorited]": 1, "subscription_option[postedannouncement]": 1, "subscriptions[postedannouncement]": 1, "subscription_option[scheduledevent]": 1, "subscriptions[scheduledevent]": 1, "subscription_option[selectednewpotw]": 1, "subscriptions[selectednewpotw]": 1, "subscription_option[promotednewadmin]": 1, "subscriptions[promotednewadmin]": 1, "subscription_option[receivesgroupcomment]": 1, "subscriptions[receivesgroupcomment]": 1, "subscription_option[greenlightannouncement]": 1, "subscriptions[greenlightannouncement]": 1, "subscription_option[workshopannouncement]": 1, "subscriptions[workshopannouncement]": 1, "subscription_option[curatorrecommendations]": 1, "subscriptions[curatorrecommendations]": 1, "subscription_option[followingpublishedugc]": 1, "subscriptions[followingpublishedugc]": 1, "subscription_option[taggedinscreenshot]": 1, "subscriptions[taggedinscreenshot]": 1 }, function(response) { if (response.success === false) { jQuery("#log_body1")[0].innerHTML += "<a style='color:#ff2c85;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 设置备注失败了! ' + profileID + ' ' + name + ' ' + response.error + "</a><br>"; } else { jQuery("#log_body1")[0].innerHTML += '[' + (i + 1) + '/' + total + '] ' + "成功设置备注于 <a target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a>" + "<a style='color:#FB7299;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + "</a><br>"; } }).fail(function() { jQuery("#log_body1")[0].innerHTML += '<span style="color:#DA2626;">[' + (i + 1) + '/' + total + '] ' + "无法设置备注于 <a style='color:#DA2626;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a></span><br>"; }).always(function() { jQuery("#log_head1").html("<br><b>当前处理了 " + (i + 1) + "个, 总计 " + total + " 个好友.<b>"); }); } setGetActivityInfo(){ //设置动态的内容为指定的数据 } setGetActivityAll(){ //设置动态内容为默认(全部) } setFriendActivityInfo(){ //设置指定好友动态为跳过,只给指定好友点赞等等 } } class SteamData{ constructor(arg) { this.steamCommunityUrl = "https://steamcommunity.com/"; this.customUrl = "id/"; this.profileIDUrl = "profiles/"; this.commentUrl = "/allcomments"; //GET //https://steamcommunity.com/id/miku-39/allcomments this.commentNextUrl = "https://steamcommunity.com/comment/Profile/render/"; //POST //https://steamcommunity.com/comment/Profile/render/76561198373290430/-1/ // start: 0 // totalcount: 11596 // count: 50 // sessionid: 006825ba8313e097671eb93e // feature2: -1 // { // start: 50, // totalcount: 11594, // count: 50, // sessionid: 006825ba8313e097671eb93e, // feature2: -1 // } // start: 100 // totalcount: 11595 // count: 50 // sessionid: 006825ba8313e097671eb93e // feature2: -1 this.statusUrl = "https://steamcommunity.com/actions/GetNotificationCounts"; //GET this.userInfoUrl = "https://steamcommunity.com/miniprofile/"; //GET //https://steamcommunity.com/miniprofile/859694761 } getCommentData(){ var url = this.steamCommunityUrl + this.customUrl + 'miku-39' + this.commentUrl; var currentCommentNum = 0; //当前评论数 var newCurrentCommentNum = 0; //在获取数据时,又出现了新的当前评论数 for (let i = 0; i < currentCommentNum; i++) { _getCommentPageData(url,i); //解析数据 //存储数据 } } _getCommentPageData(url,nPage){ var data; //获取数据 //解析数据 //完成后 _updateData(); return data; } _updateData(){ //更新当前评论数 newCurrentCommentNum = 0; } } /** * steamExtend.js * @file 存储对当前steam的功能增强代码 [steam功能拓展] */ function addRemoveFriendRemind(){ /*添加删除好友提醒*/ let obj = document.getElementsByClassName("manage_action btnv6_lightblue_blue btn_medium"); for (let i = 0; i < obj.length; i++) { if(obj[i].onclick == null) continue; let funcText = obj[i].onclick.toString(); if(funcText.indexOf("ExecFriendAction('remove', 'friends/all')") != -1) //是否是移除好友按钮 { obj[i].onclick = ()=>{ ShowConfirmDialog('您点击了移除好友按钮', '是否要移除选择的好友?','移除好友').done( function(){ console.log("移除好友"); ExecFriendAction('remove', 'friends/all'); }).fail( function(){ console.log("取消移除好友"); }); } return 1; } } return 0; } //----------------------------------------------------------------------------------- function getLoginStatus(){ if(g_steamID == false) return false; //没有登陆 else if(typeof g_steamID == "string" && g_steamID.indexOf('7656119')==0) return true; //成功登陆 } //------------------------------------------------------------------------------------------------------------- function addFriendMultipleSelectionMode(){ //添加好友多选模式 var key_mode = 0; var index_arr = [2]; index_arr[0] = undefined; index_arr[1] = undefined; var obj = document.getElementById("search_text_box"); obj && obj.blur(); //搜索框取消获得的焦点 jQuery("#search_results .selectable").click(function(e) { var id = jQuery(this).attr("id"); //id var index = jQuery(this).index(); //下标 //console.log(id,index);//得到点击的a标签的title值 switch (key_mode){ case 0: index_arr[0] = index-2; //console.log(index_arr[0]); break; case 1: //~ 反选 break; case 2: //alt 重新选择 break; case 3: //shift 好友快速多选模式 if(index_arr[0] == undefined) index_arr[0] = index-2; else if(index_arr[0] == index-2){ //同一个元素 } else{ //取消选择文字 document.selection && document.selection.empty && ( document.selection.empty(), 1) || window.getSelection && window.getSelection().removeAllRanges(); //遍历并选择之间的内容 index_arr[1] = index-2; var obj = jQuery("#search_results>.selectable"); var arr = obj.slice( index_arr[0],index_arr[1]); arr.addClass("selected"); for (let i = 0; i < arr.length; i++) { arr[i].getElementsByClassName("select_friend_checkbox")[0].checked = true; //选中 } UpdateSelection(); //官方,更新计数 console.log("好友快速多选已完成!",index_arr[0],index_arr[1]); //index_arr[0] = undefined; //index_arr[1] = undefined; } break; default: break; } }); //选择的朋友总数 document.addEventListener("keydown", function(e){ //~ 反选 //console.log(e.keyCode); //console.log(e.shiftKey,e.altKey); if(e.keyCode == 192){ key_mode = 1; //console.log("~ down"); var obj = jQuery("#search_results>.selectable"); obj.toggleClass("selected"); for (let i = 0; i < obj.length; i++) { var bool = obj[i].getElementsByClassName("select_friend_checkbox")[0].checked; obj[i].getElementsByClassName("select_friend_checkbox")[0].checked = !bool; //全部取消选中 } UpdateSelection(); //官方,更新计数 console.log("~ 反选"); return false; } }, false); //----------------------------------------------------------------------------------- shortcut.add("Esc",function() { //alt 重新选择 key_mode = 2; //console.log("Alt"); var obj = jQuery("#search_results>.selectable"); obj.removeClass("selected"); for (let i = 0; i < obj.length; i++) { obj[i].getElementsByClassName("select_friend_checkbox")[0].checked = false; //全部取消选中 } UpdateSelection(); //官方,更新计数 console.log("Esc 重新选择"); }, { 'type':'keydown', //事件 'propagate':false, //是否支持冒泡 'disable_in_input':false, //是否在输入框内有效 'target':document, //作用范围 }); //----------------------------------------------------------------------------------- shortcut.add("Shift",function() { //shift 好友快速多选模式 key_mode = 3; //console.log("Shift"); }, { 'type':'keydown', //事件 'propagate':false, //是否支持冒泡 'disable_in_input':false, //是否在输入框内有效 'target':document, //作用范围 }); //----------------------------------------------------------------------------------- document.addEventListener("keyup", function(e){ //console.log(e.keyCode); //console.log(e.shiftKey,e.altKey); if(e.keyCode == 192){ key_mode = 0; //console.log("~ UP"); return false; } else if(e.keyCode == 27){ key_mode = 0; //console.log("Esc UP"); return false; } else if(e.keyCode == 16){ key_mode = 0; //console.log("Shift UP"); return false; } }, false); } //------------------------------------------------------------------------------------------------------------------------------------------------- function getSelectedText() { if (window.getSelection) { return window.getSelection().toString(); } else if (document.selection) { return document.selection.createRange().text; } return ''; } function selectText(element) { var text = document.getElementById(element); text.focus(); text.select(); var selection = window.getSelection(); return selection.toString(); } function getDifferentIndex(str1,str2){ var length = str1.length < str2.length ? str2.length : str1.length; //取最大长度 var value; //相差的长度 if(length == str1.length) value= str1.length - str2.length; else value= str2.length - str1.length; var i; for (i = 0; i < length; i++) { if(str1.charCodeAt(i) != str2.charCodeAt(i)) //如果超出范围charCodeAt()返回NaN { if(str1.charCodeAt(i) == NaN || str2.charCodeAt(i) == NaN) return i+value; //选择的是末尾,从不一样的位置+不一样的长度 else return i; //选择的是中间,两个数不一样,返回不一样的位置 } } return -1; //没有找到返回-1 } async function setSelectTextMode(mode){ var eleName; const text_format = [{ tag_start: "[h1]", tag_end: "[/h1]" },{ tag_start: "[b]", tag_end: "[/b]" },{ tag_start: "[u]", tag_end: "[/u]" },{ tag_start: "[i]", tag_end: "[/i]" },{ tag_start: "[strike]", tag_end: "[/strike]" },{ tag_start: "[spoiler]", tag_end: "[/spoiler]" },{ tag_start: "[noparse]", tag_end: "[/noparse]" },{ tag_start: "[url=", tag_middle: "]", tag_end: "[/url]" } ] var ele; switch (inBoxonblurID){ case 0: ele = document.getElementById("comment_textarea"); eleName = "comment_textarea"; break; case 1: ele = document.getElementById("comment_textarea_en"); eleName = "comment_textarea_en"; break; case 2: ele = document.getElementById("comment_textarea_jp"); eleName = "comment_textarea_jp"; break; case 3: ele = document.getElementById("comment_textarea_zhc"); eleName = "comment_textarea_zhc"; break; case 4: ele = document.getElementById("comment_textarea_zh_sg"); eleName = "comment_textarea_zh_sg"; break; case 5: ele = document.getElementById("comment_textarea_zh_hant"); eleName = "comment_textarea_zh_hant"; break; case 6: ele = document.getElementById("comment_textarea_zh_hk"); eleName = "comment_textarea_zh_hk"; break; case 7: ele = document.getElementById("comment_textarea_zh_mo"); eleName = "comment_textarea_zh_mo"; break; case 8: ele = document.getElementById("comment_textarea_zh_tw"); eleName = "comment_textarea_zh_tw"; break; default: break; } //debugger var str = getSelectedText(); //获取选择的文本内容 var oldText = ele.value; //输入框原来的值 document.activeElement.value var selection = window.getSelection(); var selectionStr = selection.toString(); //为了区分是全选了还是根本就没有选择 var obj = ele; //当前焦点所在的元素 document.activeElement var nSelectionStart; var elTextArea; if(str == ""){ //是否没有选择任何的文本 elTextArea = ele; //设置为指定的留言框 document.activeElement if (elTextArea) { nSelectionStart = elTextArea.selectionStart;// if(nSelectionStart == undefined) //如果没有输入 { nSelectionStart = 0; elTextArea.value = ""; } newMess = elTextArea.value.substr(0, nSelectionStart); } } else{ var iindex = ele.selectionStart; // await window.getSelection().deleteFromDocument(); /*删除选择的文本*/ var newText = selectText(eleName); //输入框现在的值 if(newText == oldText){ //debugger return; } //debugger var index; // if(iindex != 0 )//是否在开头(针对于相同的字符) // index = getDifferentIndex(oldText,newText); //getDifferentIndex(oldText,newText); //ele.selectionStart // else index = iindex; console.log("index",index); var endIndex = index + str.length; var newMess = oldText.slice(0,index); //添加开头 } switch (mode){ case 1: newMess += text_format[0].tag_start + str + text_format[0].tag_end; //处理选择的文本并添加 if(selectionStr == "" && selection.toString() == ""){ //为了区分是全选了还是根本就没有选择 elTextArea.selectionStart = nSelectionStart + (text_format[0].tag_start + str + text_format[0].tag_end).length; } break; case 2: newMess += text_format[1].tag_start + str + text_format[1].tag_end; //处理选择的文本并添加 if(selectionStr == "" && selection.toString() == ""){ elTextArea.selectionStart = nSelectionStart + (text_format[1].tag_start + str + text_format[1].tag_end).length; } break; case 3: newMess += text_format[2].tag_start + str + text_format[2].tag_end; //处理选择的文本并添加 if(selectionStr == "" && selection.toString() == ""){ elTextArea.selectionStart = nSelectionStart + (text_format[2].tag_start + str + text_format[2].tag_end).length; } break; case 4: newMess += text_format[3].tag_start + str + text_format[3].tag_end; //处理选择的文本并添加 if(selectionStr == "" && selection.toString() == ""){ elTextArea.selectionStart = nSelectionStart + (text_format[3].tag_start + str + text_format[3].tag_end).length } break; case 5: newMess += text_format[4].tag_start + str + text_format[4].tag_end; //处理选择的文本并添加 if(selectionStr == "" && selection.toString() == ""){ elTextArea.selectionStart = nSelectionStart + (text_format[4].tag_start + str + text_format[4].tag_end).length; } break; case 6: newMess += text_format[5].tag_start + str + text_format[5].tag_end; //处理选择的文本并添加 if(selectionStr == "" && selection.toString() == ""){ elTextArea.selectionStart = nSelectionStart + (text_format[5].tag_start + str + text_format[5].tag_end).length; } break; case 7: newMess += text_format[6].tag_start + str + text_format[6].tag_end; //处理选择的文本并添加 if(selectionStr == "" && selection.toString() == ""){ elTextArea.selectionStart = nSelectionStart + (text_format[6].tag_start + str + text_format[6].tag_end).length; } break; case 8: newMess += text_format[7].tag_start + text_format[7].tag_middle + str + text_format[7].tag_end; //处理选择的文本并添加 if(selectionStr == "" && selection.toString() == ""){ elTextArea.selectionStart = nSelectionStart + (text_format[7].tag_start + str + text_format[7].tag_end).length; } break; default: break; } if(selectionStr == "" && selection.toString() == ""){ //是否没有选择任何的文本 newMess += elTextArea.value.substr(nSelectionStart) } else{ newMess += oldText.slice(endIndex); //添加结尾 } obj.value = newMess; //重新赋值给输入框 obj.focus(); //获取焦点,如果不在视野里,会把镜头拉过去 } //setSelectTextMode(1) //------------------------------------------------------------------------------------------------------------------------------------------------- function add_commentthread_textarea_allSelect(){ //添加留言框全选 document.addEventListener("mousedown", function(e){ //console.log(e.button); if(e.button == 1){ if(document.activeElement.id.indexOf("comment_textarea") != -1){ //当前焦点所在的元素如果是留言框才全选 let obj; switch (inBoxonblurID){ case 0: obj = document.getElementById("comment_textarea"); break; case 1: obj = document.getElementById("comment_textarea_en"); break; case 2: obj = document.getElementById("comment_textarea_jp"); break; case 3: obj = document.getElementById("comment_textarea_zhc"); break; case 4: obj = document.getElementById("comment_textarea_zh_sg"); break; case 5: obj = document.getElementById("comment_textarea_zh_hant"); break; case 6: obj = document.getElementById("comment_textarea_zh_hk"); break; case 7: obj = document.getElementById("comment_textarea_zh_mo"); break; case 8: obj = document.getElementById("comment_textarea_zh_tw"); break; default: break; } obj.focus(); obj.select(); e.stopPropagation(); e.stopImmediatePropagation(); e.preventDefault(); return false; } return false; } }, false); document.addEventListener("keyup", function(e){ //console.log(e.keyCode); //console.log(e.shiftKey,e.altKey); if(e.keyCode == 18){ //Alt let obj; switch (inBoxonblurID){ case 0: obj = document.getElementById("comment_textarea"); break; case 1: obj = document.getElementById("comment_textarea_en"); break; case 2: obj = document.getElementById("comment_textarea_jp"); break; case 3: obj = document.getElementById("comment_textarea_zhc"); break; case 4: obj = document.getElementById("comment_textarea_zh_sg"); break; case 5: obj = document.getElementById("comment_textarea_zh_hant"); break; case 6: obj = document.getElementById("comment_textarea_zh_hk"); break; case 7: obj = document.getElementById("comment_textarea_zh_mo"); break; case 8: obj = document.getElementById("comment_textarea_zh_tw"); break; default: break; } obj.focus(); obj.select(); e.stopPropagation(); e.stopImmediatePropagation(); e.preventDefault(); //console.log("Alt UP"); return false; } }, false); } /** * utility.js */ function _addIDtoHandleLostfocus(){ //添加ID来处理丢失的焦点 var parentObj = document.getElementById("steamTextStyle").parentNode; Obj = parentObj.getElementsByTagName('input'); for (let i = 0; i < Obj.length; i++) { Obj[i].id = "steamTextStyle_1"; } Obj = parentObj.getElementsByTagName('dl'); for (let i = 0; i < Obj.length; i++) { Obj[i].id = "steamTextStyle_1"; } Obj = parentObj.getElementsByTagName('dd'); for (let i = 0; i < Obj.length; i++) { Obj[i].id = "steamTextStyle_1"; } } function registeMenu(){ //注册脚本快捷菜单 if(g_uiConf.isShow_menu_friend){ g_arrMenuID[0] = GM_registerMenuCommand("好友列表", function(){ window.open("https://steamcommunity.com/my/friends", "_blank"); }); } if(g_uiConf.isShow_menu_activity){ g_arrMenuID[1] = GM_registerMenuCommand("动态列表", function(){ window.open("https://steamcommunity.com/my/home", "_blank"); }); } if(g_uiConf.isShow_menu_registerKey){ g_arrMenuID[2] = GM_registerMenuCommand("激活key", function(){ window.open("https://store.steampowered.com/account/registerkey", "_blank"); }); } if(g_uiConf.isShow_menu_redeemWalletCode){ g_arrMenuID[3] = GM_registerMenuCommand("充值key", function(){ window.open("https://store.steampowered.com/account/redeemwalletcode", "_blank"); }); } if(g_uiConf.isShow_menu_steamdbFree){ g_arrMenuID[4] = GM_registerMenuCommand("SteamDB预告", function(){ window.open("https://steamdb.info/upcoming/free/", "_blank"); }); } } function unRegisteMenu(){ //取消注册脚本快捷菜单 GM_unregisterMenuCommand(g_arrMenuID[0]); GM_unregisterMenuCommand(g_arrMenuID[1]); GM_unregisterMenuCommand(g_arrMenuID[2]); GM_unregisterMenuCommand(g_arrMenuID[3]); GM_unregisterMenuCommand(g_arrMenuID[4]); } function registeNotification(){ //注册事件完成通知 var options = { text: "文本.", title: "标题!", image: "https://steamcommunity-a.akamaihd.net/public/shared/images/responsive/share_steam_logo.png", ondone: function() { console.log("完成."); }, onclick: function() { console.log("点击."); } } GM_notification(options); } function setPageRefreshAndCloseWarn(mode){ //设置页面刷新和关闭警告 var func_PageRefreshAndCloseWarn = function(event){ event.returnValue = '当前脚本正在运行中,您确定要离开吗?'; }; if (mode) { window.addEventListener("beforeunload", func_PageRefreshAndCloseWarn, true); } else{ window.removeEventListener("beforeunload", func_PageRefreshAndCloseWarn, true) } } //setPageRefreshAndCloseWarn(true); //设置页面刷新和关闭警告 //setPageRefreshAndCloseWarn(false); //取消设置页面刷新和关闭警告 function autoSetPageRefreshAndCloseWarn(mode){ //自动判断状态并设置页面刷新和关闭警告 var func_autoPageRefreshAndCloseWarn = function(event){ if(g_conf[0].YunStatus == true){ if(g_conf[0].isAddYunBreakWarn == true){ event.returnValue = '当前脚本正在运行中,您确定要离开吗?'; } } }; if (mode) { window.addEventListener("beforeunload", func_autoPageRefreshAndCloseWarn, true); } else{ window.removeEventListener("beforeunload", func_autoPageRefreshAndCloseWarn, true) } } //autoSetPageRefreshAndCloseWarn(true); //自动判断状态并设置页面刷新和关闭警告 //autoSetPageRefreshAndCloseWarn(false); //取消自动判断状态并设置页面刷新和关闭警告 //------------------------------------------------------------------------------------------------------------- // API function getCityCodeByEnglishName(cityEnglishName) { if (g_arrCityList == undefined) return null; for (let i = 0; i < g_arrCityList.length; i++) { if (g_arrCityList[i][1].length == cityEnglishName.length && g_arrCityList[i][1].toLowerCase() == cityEnglishName.toLowerCase()) { return g_arrCityList[i][0]; } } return null; } function getCityCodeByChinsesName(cityChinseshName) { if (g_arrCityList == undefined) return null; for (let i = 0; i < g_arrCityList.length; i++) { if (g_arrCityList[i][3].length == cityChinseshName.length && g_arrCityList[i][3].toLowerCase() == cityChinseshName.toLowerCase()) { return g_arrCityList[i][0]; } } return null; } function getCityChinsesNameByEnglishName(cityEnglishName) { if (g_arrCityList == undefined) return null; for (let i = 0; i < g_arrCityList.length; i++) { if (g_arrCityList[i][1].length == cityEnglishName.length && g_arrCityList[i][1].toLowerCase() == cityEnglishName.toLowerCase()) { return g_arrCityList[i][3]; } } return null; } //------------------------------------------------------------------------------------------------------------- //RGB function countRgbColor(r, g, b) //计算RGB渐变颜色 { var color; //var color = '#' + to2string(r) + 'ffff'; //console.log(color); //return color; while (true) { switch (RGBindex) { case 0: //红 if (RGBr == 0 & RGBg == 0 & RGBb == 0) { RGBr = 0xFF; //红 color = '#' + to2string(RGBr) + to2string(RGBg) + to2string(RGBb); //console.log("color:" + color); return color; } else { RGBindex = 1; continue; //重新开始 } break; case 1: //红->黄 if (RGBg != 0xFF) { RGBg += 3; //红->黄 color = '#' + to2string(RGBr) + to2string(RGBg) + to2string(RGBb); //console.log("color:" + color); return color; } else { RGBindex = 2; continue; //重新开始 } break; case 2: //黄->绿 if (RGBr != 0x00) //黄 { RGBr -= 3; //黄->绿 color = '#' + to2string(RGBr) + to2string(RGBg) + to2string(RGBb); //console.log("color:" + color); return color; } else { RGBindex = 3; continue; //重新开始 } break; case 3: //绿->蓝(天蓝) if (RGBb != 0xFF) { if (RGBg > 0xBF) { RGBg -= 3; } RGBb += 3; color = '#' + to2string(RGBr) + to2string(RGBg) + to2string(RGBb); //console.log("color:" + color); return color; } else { RGBindex = 4; continue; //重新开始 } break; case 4: //蓝(天蓝)->蓝(深蓝) if (RGBg != 0x00) { RGBg -= 3; color = '#' + to2string(RGBr) + to2string(RGBg) + to2string(RGBb); //console.log("color:" + color); return color; } else { RGBindex = 5; continue; //重新开始 } break; case 5: //蓝(深蓝)->紫 if (RGBr < 0x80 || RGBb > 0x80) { if (RGBr < 0x80) { RGBr += 3; color = '#' + to2string(RGBr) + to2string(RGBg) + to2string(RGBb); //console.log("color:" + color); return color; } else if (RGBb > 0x80) { RGBb -= 3; color = '#' + to2string(RGBr) + to2string(RGBg) + to2string(RGBb); //console.log("color:" + color); return color; } } else { RGBindex = 6; continue; //重新开始 } break; case 6: //紫->红 if (RGBr != 0xFF || RGBb != 0x00) { if (RGBr < 0xFF) { RGBr += 3; color = '#' + to2string(RGBr) + to2string(RGBg) + to2string(RGBb); //console.log("color:" + color); return color; } else if (RGBb > 0x00) { RGBb -= 3; color = '#' + to2string(RGBr) + to2string(RGBg) + to2string(RGBb); //console.log("color:" + color); return color; } } else //继续RGB { RGBindex = 1; continue; //重新开始 } break; case 7: console.log("end!!!"); break; default: console.log("[countRgbColor()-switch(RGBindex):] 未定义异常!") break; } } //红 #FF0000 //黄 #FFFF00 //绿 #00FF00 //蓝 #00BFFF #0000FF //紫 #800080 } // function setRgb() //设置RGB渐变颜色 // { // var loginBox = document.getElementById("LoginBaseBox"); // loginBox.style.background = countRgbColor(0,0,0); // } // var tiSysCallback_runRGB = setInterval(function(){runRGB();}, 22); //[启动定时器] 每秒回调函数 // 11 16 22 30 //------------------------------------------------------------------------------------------------------------- function setBackgroundImg(imgFilePath,type){ //设置背景图片 if(jQuery("#backgroundIMG")[0] == undefined) jQuery("body").prepend('<div id="backgroundIMG">背景图</div>'); if(type == "img"){ var css = "background: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url('"+ imgFilePath +"') no-repeat fixed;background-size: cover; width: 100%;"; //var css = "background: rgba(0,0,0,0) url('"+ imgFilePath +"') no-repeat fixed;background-size: cover; width: 100%;"; var other_css = "position: absolute; z-index: -1; height:100%;"; var opacity_css = "opacity:1;filter: alpha(opacity=100)"; jQuery("#backgroundIMG")[0].style = css + other_css + opacity_css; document.body.style.background = "none"; //去除原背景 jQuery(".friends_header_bg")[0].style.background = "none"; //去除 上面那层蓝色背景图片 jQuery("#global_header")[0].style.background = "linear-gradient(rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6))"; //设置 最上面设置黑色区域透明度 jQuery(".content")[0].style.background = "none"; //去除 最上面黑色区域 var obj = jQuery(".profile_friends.title_bar")[0]; if(obj != undefined) obj.style.background = "linear-gradient(rgba(1, 94, 128, 0.6), rgba(1, 94, 128, 0.6))"; //设置 管理好友列表那块的透明度 }else if(type == "bin"){ jQuery("#backgroundIMG").attr("src", "data:" + imageType + ";base64," + data); } } function setBackgroundImgCarousel(arr_img,timeInterval){ //设置背景图片轮播(图片路径,时间间隔) //URL()存的图片网络地址 修改背景图 就改这个地址 必须要网络地址噢噢噢(注意这里没有[img][/img]) 壁纸 可以在这找 https://www.enterdesk.com/zhuomianbizhi/dongmankatong/dongmanrenwu/ var x = 0; //记录当前第几张轮播图 setBackgroundImg(arr_img[x++],"img"); setInterval(()=>{ if (x >= arr_img.length) x = 0; setBackgroundImg(arr_img[x++],"img"); }, timeInterval); } async function getNetImgBysourceID(sourceID){ var data,obj,imgFilePath; if(sourceID==0){ data = await gc_exApis.getDataByApiList(1,0,"json"); if(data.indexOf('{')!=0){ console.log("服务器返回了错误的数据,尝试重新请求: "+ data); return getNetImgBysourceID(sourceID); } obj = JSON.parse(data); //JSON处理并解析到js对象 if(obj.code == 200){ imgFilePath = obj.imgurl; } } else if(sourceID==1){ data = await gc_exApis.getDataByApiList(2,0,"json"); if(data.indexOf('{')!=0){ console.log("服务器返回了错误的数据,尝试重新请求: "+ data); return getNetImgBysourceID(sourceID); } obj = JSON.parse(data); //JSON处理并解析到js对象 if(obj.code == 200){ imgFilePath = obj.imgurl; } } return imgFilePath; } async function binImgDatatoBase64(res){ //二进制图片数据转base64编码后直接显示 var arr = res.responseHeaders.split('\r\n'); var arr1 = []; for (let i = 0; i < arr.length; i++) { var str1 = arr[i].slice(0,arr[i].indexOf(':')); var str2 = arr[i].slice(arr[i].indexOf(':') +1); arr1.push([str1,str2]); } var getResponseHeader = (name)=>{ for (let i = 0; i < arr1.length; i++) { if(arr1[i][0] == name){ return arr1[i][1]; } } }; var imageType = getResponseHeader("content-type"); var blob = new Blob([res.response], { type: imageType }); var reader = new FileReader(); var imgBase64 = reader.readAsDataURL(blob); reader.addEventListener("load", function () { console.log(reader.result); setBackgroundImg(reader.result,"img"); }, false); var imageUrl = (window.URL || window.webkitURL).createObjectURL(blob); //setBackgroundImg(imageUrl,"img"); // var uInt8Array = new Uint8Array(res.response); // var i = uInt8Array.length; // var binaryString = new Array(i); // while (i--) { // binaryString[i] = String.fromCharCode(uInt8Array[i]); // } // var data = binaryString.join(''); // debugger // var imageType = res.getResponseHeader("Content-Type"); //setBackgroundImg(imgFilePath,"bin"); } async function binImgDatatoBlob(){ //二进制图片数据转Blob对象 } async function autoGetImgAndSetBackgroundImg(sourceID,mode,timeInterval,maxImgNumber){ //来源id, 模式:true轮播,false不轮播, 时间间隔(不轮播就无效), 最大图片轮播数量(不轮播就无效) var arr_img = []; var imgFilePath; if(mode == true){ imgFilePath = await getNetImgBysourceID(sourceID); arr_img[0] = imgFilePath; if(maxImgNumber > 0){ setTimeout(async()=>{ for (let i = 0; i < maxImgNumbers; i++) { imgFilePath = await getNetImgBysourceID(sourceID); arr_img.push(imgFilePath) } }, 0); setBackgroundImgCarousel(arr_img,timeInterval); }else{ setBackgroundImg(imgFilePath,"img"); setInterval(async()=>{ imgFilePath = await getNetImgBysourceID(sourceID); setBackgroundImg(imgFilePath,"img"); }, timeInterval); } }else if(mode == false){ imgFilePath = await getNetImgBysourceID(sourceID); //var jsData = await getResourceByURL(imgFilePath,false); //binImgDatatoBase64(jsData); setBackgroundImg(imgFilePath,"img"); } //gc_exApis.getDataByApiList(0); //gc_exApis.getDataByApiList(1,0,"json"); //gc_exApis.getDataByApiList(1,0); //gc_exApis.getDataByApiList(2,0,"json"); //gc_exApis.getDataByApiList(2,0); //gc_exApis.getDataByApiList(2,1,"二维码文本"); //gc_exApis.getDataByApiList(3,0,"","Miku"); //gc_exApis.getDataByApiList(3,1,"","Miku"); //gc_exApis.getDataByApiList(3,2,"","Miku"); //gc_exApis.getDataByApiList(3,3,"","Miku"); //gc_exApis.getDataByApiList(4,0); //gc_exApis.getDataByApiList(4,1,1); //gc_exApis.getDataByApiList(4,2,"Miku"); //gc_exApis.getDataByApiList(4,3); //gc_exApis.getDataByApiList(4,4); } //------------------------------------------------------------------------------------------------------------- function downFile(type,data,fileName) { var elementA = document.createElement('a'); if(type == "json") //json对象 elementA.setAttribute('href', 'data:text/plain;charset=utf-8,' + JSON.stringify(data)); else if(type == "text") //文本 elementA.setAttribute('href', 'data:text/plain;charset=utf-8,' + data); else if(type == "bin") //二进制数据 elementA.setAttribute('href', 'data:text/plain;charset=utf-8,' + data); else{ alert("不支持的数据类型!!"); elementA.setAttribute('href', 'data:text/plain;charset=utf-8,' + data); } //if(fileName == undefined) fileName = new Date(); elementA.setAttribute('download', + new Date() + ".data"); elementA.style.display = 'none'; document.body.appendChild(elementA); elementA.click(); document.body.removeChild(elementA); } //downFile("json",g_conf,"SteamAssistant"); //设置透明 https://www.52pojie.cn/thread-763424-1-1.html //background: rgba(229, 241, 240,0); //background: transparent; //------------------------------------------------------------------------------------------------------------- //------------------------------------------------------------------------------------------------------------- //------------------------------------------------------------------------------------------------------------- //------------------------------------------------------------------------------------------------------------- /** */ class multiLanguage{ constructor(arg) { this.l_en = 'en_GB'; this.l_cn = 'zh_CN'; this.l_tw = 'zh_TW'; this.l_jp = 'jp_JP'; this.l_auto = 'auto_detected'; } /** * 初始化 */ init(){ jQuery('#selectLanguageDropdown').localizationTool(languagesList_mainUI_html); //初始化 this.readConfig(); //读取当前语言配置 } /** * 读取当前语言配置 */ readConfig(){ if(g_conf[0].language == "auto_detected"){ this.setAutoDetected(); } else{ jQuery('#selectLanguageDropdown').localizationTool('translate',g_conf[0].language); } } /** * 保存当前语言配置 */ saveConfig(lang){ g_conf[0].language = lang; } /** * 设置为自动检测 */ setAutoDetected(){ var arrLang = navigator.languages; for (let i = 0; i < arrLang.length; i++) { if(arrLang[i].indexOf('en') != -1){ //英语系 "en-US", "en"等变种语言 jQuery('#selectLanguageDropdown').localizationTool('translate',this.l_en); return true; } switch (arrLang[i]){ case "zh-CN": //简体 jQuery('#selectLanguageDropdown').localizationTool('translate',this.l_cn); return true; break; case "zh-TW": //繁体 jQuery('#selectLanguageDropdown').localizationTool('translate',this.l_tw); return true; break; case "ja": //日语 jQuery('#selectLanguageDropdown').localizationTool('translate',this.l_jp); return true; break; } } jQuery('#selectLanguageDropdown').localizationTool('translate',this.l_en); return false; } } /** * ui.js */ //UI处理逻辑: //您的好友 普通UI 添加将选择的玩家添加到指定分组的选项 //添加好友 不处理 //待处理邀请 精简版普通UI-1 添加将选择的玩家添加到指定分组的选项 //已屏蔽 精简版普通UI-2 //直播版主 版主UI //关注的玩家 精简版普通UI-0 添加将选择的玩家添加到指定分组的选项 //关注的游戏... 不处理,因为会覆盖当前页面 //您的组 组留言UI-1 添加将选择的组添加到指定分组的选项 //待处理邀请 组留言UI-2 添加将选择的组添加到指定分组的选项 //查找组... 不处理,因为会覆盖当前页面 //创建组... 不处理,因为会覆盖当前页面 /** * @class * @classdesc UI类 * @abstract 必须在继承的子类中实现 */ class UI { constructor(arg) { this.loadProgress = 0; //加载进度 this.isDomLoaded = false; //dom是否加载完毕 registeMenu(); //注册脚本快捷菜单 //registeNotification(); //注册事件完成通知 if(gc_multiLanguage == null) gc_multiLanguage = new multiLanguage(); //多语言支持 } showLoadUI(){ // addNewStyle('styles_loading',load_cssCode); var obj = document.getElementsByClassName("v6 game_bg responsive_page")[0]; //body var objElement = document.createElement('div'); objElement.id="loadingUI" //<div id="loadingUI">\ //</div> objElement.style = loadUI_css; objElement.innerHTML = loadUI_Html; obj.appendChild(objElement); console.log("showLoadUI()"); } loadTextChange(mode){ //改变当前加载进度 if(this.isDomLoaded == false){ this.loadProgress++; } else{ var obj = document.getElementsByClassName('how-to')[0]; obj.innerText = "正在加载资源中,已完成"+ (++this.loadProgress) + "/10,请您耐心等待..."; } } remoreLoadUI(){ //移除加载UI和css if((()=>{ var obj = document.getElementsByClassName("v6 game_bg responsive_page")[0]; //body var objChildNodes = obj.childNodes; //childNodes for (let i = 0; i < objChildNodes.length; i++) { if(objChildNodes[i].id == "loadingUI"){ obj.removeChild(objChildNodes[i]); //移除加载UI return true; } } return false; })() == false){ console.log("移除加载UI失败~!"); return false; } if((()=>{ var obj = document.getElementsByTagName("head")[0]; //head var objChildNodes = obj.childNodes; //childNodes for (let i = 0; i < objChildNodes.length; i++) { if(objChildNodes[i].id == "styles_loading"){ obj.removeChild(objChildNodes[i]); //移除css return true; } } return false; })() == false){ console.log("移除css失败~!"); return false; } return true; } // 添加留言高级设置UI // 设置多个留言框按顺序留言+++ // 设置多次留言 // 设置留言优先级 // 设置简单留言自动回复和特殊留言提醒功能 async initUI(type) { //type: true: 第一次加载, false: 再加载 (async()=>{ await autoGetImgAndSetBackgroundImg(0,false,5000,0); //加载背景图片 })(); jQuery(".icon_item.icon_all_friends")[0].style.color ="#66ccff"; //您的好友 jQuery(".icon_item.icon_blocked_friends")[0].style.color ="#66ccff"; //已屏蔽 jQuery(".icon_item.icon_all_friends")[1].style.color ="#66ccff"; //直播版主 jQuery(".icon_item.icon_all_following")[0].style.color ="#66ccff"; //关注的玩家 jQuery(".icon_item.icon_all_groups")[0].style.color ="#66ccff"; //您的组 } async createUI() { //好友数据统计里的置顶和是否锁定的模板 jQuery("#manage_friends").after(mainUI_template); } async reCreateUI(){ if(await gc_menu_friends_ui.initUI(false) != false){ await gc_menu_friends_ui.createUI(); } } f async private_saveUIConfFile() { } async private_readUIConfFile() { } } var isReCreateUi = ()=>{ //是否重新创建Ui(url正则表达式,回调函数) var url = window.location.origin + window.location.pathname; //window.location.href //去除参数和锚点后的url var _fn = ()=>{ _ySelects(jQuery); g_conf[0].YunStatus = false; /*当前运行状态(比如正在留言中之类的就是正在运行)*/ g_conf[0].isTranslationText = false; /*是否进行了翻译*/ g_conf[0].isWarnInfo = false; /*是否出现警告信息(如果没有则不需要清空)*/ g_conf[0].isCommentRunStatus = false; /*是否正在留言*/ g_conf[0].isNationalityRunStatus = false; /*是否正在设置国籍*/ g_conf[0].isNoCommentRunStatus = false; /*是否正在设置不留言*/ g_conf[0].isTimeIntervalRunStatus = false; /*是否正在设置留言时间间隔*/ g_conf[0].isAutoCommentRunStatus = false; /*是否正在设置自动留言计划*/ g_conf[0].isFriendToGroupRunStatus = false; /*是否正在设置好友分组*/ }; //https://steamcommunity.com/id/miku-39/friends?l=english#state_online => https://steamcommunity.com/id/miku-39/friends if(URLs.g_friendUrlRegExp.test(url)){ _fn(); console.log("重新构建UI-您的好友."); gc_menu_friends_ui && typeof gc_menu_friends_ui.reCreateUI === 'function' && gc_menu_friends_ui.reCreateUI(); //调用回调 } else if(URLs.g_otherUrlRegExp1_1.test(url)){ _fn(); console.log("不处理-添加好友."); //不处理 return; } else if(URLs.g_otherUrlRegExp1_2.test(url)){ _fn(); console.log("不处理-好友待处理邀请."); //暂时 不处理 return; } else if(URLs.g_otherUrlRegExp1_3.test(url)){ _fn(); console.log("重新构建UI-已屏蔽."); gc_menu_shielding_ui && typeof gc_menu_shielding_ui.reCreateUI === 'function' && gc_menu_shielding_ui.reCreateUI(); //调用回调 return; } else if(URLs.g_otherUrlRegExp1_4.test(url)){ _fn(); console.log("不处理-近期共同游戏的玩家."); //暂时 不处理 return; } else if(URLs.g_otherUrlRegExp1_5.test(url)){ _fn(); console.log("重新构建UI-直播版主."); gc_menu_liveAdmin_ui && typeof gc_menu_liveAdmin_ui.reCreateUI === 'function' && gc_menu_liveAdmin_ui.reCreateUI(); //调用回调 return; } else if(URLs.g_otherUrlRegExp2_1.test(url)){ _fn(); console.log("重新构建UI-关注的玩家."); gc_menu_following_Players_ui && typeof gc_menu_following_Players_ui.reCreateUI === 'function' && gc_menu_following_Players_ui.reCreateUI(); //调用回调 return; } else if(URLs.g_otherUrlRegExp2_2.test(url)){ //_fn(); //console.log("重新构建UI-您的组."); window.location.reload(true); //重新加载当前页面 //gc_menu_groups_ui && typeof gc_menu_groups_ui.reCreateUI === 'function' && gc_menu_groups_ui.reCreateUI(); //调用回调 return; } else if(URLs.g_otherUrlRegExp2_3.test(url)){ _fn(); console.log("不处理UI-组待处理邀请!"); //window.location.reload(true); //重新加载当前页面 //暂时 不处理 return; } // else if(URLs.g_otherUrlRegExp3.test(url)){ // console.log("重新构建UI-您的好友."); // gc_menu_friends_ui && typeof gc_menu_friends_ui.reCreateUI === 'function' && gc_menu_friends_ui.reCreateUI(); //调用回调 // } }; //------------------------------------------------------------------------------------------------------------------------------------------------------------------- /** * UI类 - 您的好友 模块 UI具体实现 * @class * @classdesc UI类 - 您的好友 模块 UI具体实现 * @extends UI */ class menu_friends_ui extends UI { constructor(arg) { super(); } async initUI(type) { //type: true: 第一次加载, false: 再加载 super.initUI(); // 设置数据库 // var db = new DB(); // db.Test(); // db.initAndCreateNewDBInstance({ // driver: [localforage.WEBSQL, // localforage.INDEXEDDB, // localforage.LOCALSTORAGE], // name: 'Steam assistant-Conf', // size: 10485760 //10mb // }); g_db = new DB({ //设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Conf', size: 10485760 //10mb },true); g_db1 = new DB({ //拓展功能 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Expand', size: 10485760 //10mb },false); g_db2 = new DB({ //动态助手 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Activity', size: 1073741824 //1gb },false); g_db3 = new DB({ //数据分析 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Friend', size: 1073741824 //1gb },false); g_db4 = new DB({ //留言设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Comment', size: 104857600 //100mb },false); await g_db.Write('g_conf',g_conf); //写入 await g_db.Write('g_uiConf',g_uiConf); //写入 //debugger //var data = await g_db.getAllKeyName(); //console.log("data",data); //var data = await g_db.getKeyNameByIndex(1); //console.log("data",data); //var data = await g_db.getLength(); //console.log("data",data); var data = await g_db.Read('g_conf'); //读取 console.log("data",data); var data = await g_db.Read('g_uiConf'); //读取 console.log("data",data); //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.Remove('g_conf'); //删除数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.RemoveAll(); //删除所有数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //if(data.length == 0){ // console.log("没有数据!"); //} if(getLoginStatus() == false){ //判断是否登录,如果没有登录则不需要继续运行 layer.alert('请先登录Steam,才能继续使用哦~', {icon: 0},function(index){ if(g_conf[0].autoLogin == 1){ var obj = document.getElementsByClassName("global_action_link"); for (let i = 0; i < obj.length; i++) { if(obj[i].className == "global_action_link"){ obj[i].click(); //跳转到登录页面 } } } }); return false; } readConfInfo(g_steamID); //读取已保存的对应配置信息 if(type){ //第一次加载才需要监听这些事件 //1.监听url中的hash变化 //window.location.hash='state_online' => https://steamcommunity.com/id/miku-39/friends#state_online //页面不刷新,url改变,定位到指定锚点 window.addEventListener('hashchange',function(event){ console.log("1.监听url中的hash变化" + event); isReCreateUi(); //是否重新创建Ui }); //2.监听通过history来改变url的事件 //浏览器前进,后退等 window.addEventListener('popstate', function(event) { console.log("2.监听通过history来改变url的事件" + event); isReCreateUi(); //是否重新创建Ui }); //3.监听pushState和replaceState行为 //pushState可以监听到本页替换超链接 var _wr = function(type) { var orig = history[type]; return function() { var rv = orig.apply(this, arguments); var e = new Event(type); e.arguments = arguments; window.dispatchEvent(e); return rv; }; }; history.pushState = _wr('pushState'); history.replaceState = _wr('replaceState'); window.addEventListener('replaceState', function(e) { console.log('监听到replaceState!'); isReCreateUi(); //是否重新创建Ui }); window.addEventListener('pushState', function(e) { console.log('监听到pushState!'); var url = window.location.origin + window.location.pathname; //window.location.href //去除参数和锚点后的url //https://steamcommunity.com/id/miku-39/friends?l=english#state_online => https://steamcommunity.com/id/miku-39/friends isReCreateUi(); //是否重新创建Ui }); } } async createUI() { super.createUI(); //正常html代码 jQuery("#manage_friends").after(mainUI_html); if(g_uiConf.isShowQuickNavigationBar){ //是否显示快速导航栏 //快捷导航栏 jQuery(".responsive_page_template_content").after(ExpandUI_QuickNavigationBar_html); } gc_multiLanguage.init(); //初始化多语言支持 UI.prototype.uiHandler(); //UI与UI事件等相关的处理程序 } async reCreateUI(){ if(await gc_menu_friends_ui.initUI(false) != false){ await gc_menu_friends_ui.createUI(); } } async private_saveUIConfFile() { } async private_readUIConfFile() { } } //------------------------------------------------------------------------------------------------------------------------------------------------------------------- /** * UI类 - 待处理邀请 模块 UI具体实现 * @class * @classdesc UI类 - 待处理邀请 模块 UI具体实现 * @extends UI */ class menu_friends_invite_ui extends UI { constructor(arg) { super(); } async initUI(type) { //type: true: 第一次加载, false: 再加载 super.initUI(); // 设置数据库 // var db = new DB(); // db.Test(); // db.initAndCreateNewDBInstance({ // driver: [localforage.WEBSQL, // localforage.INDEXEDDB, // localforage.LOCALSTORAGE], // name: 'Steam assistant-Conf', // size: 10485760 //10mb // }); g_db = new DB({ //设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Conf', size: 10485760 //10mb },true); g_db1 = new DB({ //拓展功能 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Expand', size: 10485760 //10mb },false); g_db2 = new DB({ //动态助手 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Activity', size: 1073741824 //1gb },false); g_db3 = new DB({ //数据分析 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Friend', size: 1073741824 //1gb },false); g_db4 = new DB({ //留言设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Comment', size: 104857600 //100mb },false); await g_db.Write('g_conf',g_conf); //写入 await g_db.Write('g_uiConf',g_uiConf); //写入 //debugger //var data = await g_db.getAllKeyName(); //console.log("data",data); //var data = await g_db.getKeyNameByIndex(1); //console.log("data",data); //var data = await g_db.getLength(); //console.log("data",data); var data = await g_db.Read('g_conf'); //读取 console.log("data",data); var data = await g_db.Read('g_uiConf'); //读取 console.log("data",data); //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.Remove('g_conf'); //删除数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.RemoveAll(); //删除所有数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //if(data.length == 0){ // console.log("没有数据!"); //} if(getLoginStatus() == false){ //判断是否登录,如果没有登录则不需要继续运行 layer.alert('请先登录Steam,才能继续使用哦~', {icon: 0},function(index){ if(g_conf[0].autoLogin == 1){ var obj = document.getElementsByClassName("global_action_link"); for (let i = 0; i < obj.length; i++) { if(obj[i].className == "global_action_link"){ obj[i].click(); //跳转到登录页面 } } } }); return false; } readConfInfo(g_steamID); //读取已保存的对应配置信息 if(type){ //第一次加载才需要监听这些事件 //1.监听url中的hash变化 //window.location.hash='state_online' => https://steamcommunity.com/id/miku-39/friends#state_online //页面不刷新,url改变,定位到指定锚点 window.addEventListener('hashchange',function(event){ console.log("1.监听url中的hash变化" + event); isReCreateUi(); //是否重新创建Ui }); //2.监听通过history来改变url的事件 //浏览器前进,后退等 window.addEventListener('popstate', function(event) { console.log("2.监听通过history来改变url的事件" + event); isReCreateUi(); //是否重新创建Ui }); //3.监听pushState和replaceState行为 //pushState可以监听到本页替换超链接 var _wr = function(type) { var orig = history[type]; return function() { var rv = orig.apply(this, arguments); var e = new Event(type); e.arguments = arguments; window.dispatchEvent(e); return rv; }; }; history.pushState = _wr('pushState'); history.replaceState = _wr('replaceState'); window.addEventListener('replaceState', function(e) { console.log('监听到replaceState!'); isReCreateUi(); //是否重新创建Ui }); window.addEventListener('pushState', function(e) { console.log('监听到pushState!'); var url = window.location.origin + window.location.pathname; //window.location.href //去除参数和锚点后的url //https://steamcommunity.com/id/miku-39/friends?l=english#state_online => https://steamcommunity.com/id/miku-39/friends isReCreateUi(); //是否重新创建Ui }); } } async createUI() { super.createUI(); //正常html代码 jQuery("#manage_friends").after(mainUI_html); if(g_uiConf.isShowQuickNavigationBar){ //是否显示快速导航栏 //快捷导航栏 jQuery(".responsive_page_template_content").after(ExpandUI_QuickNavigationBar_html); } UI.prototype.uiHandler(); //UI与UI事件等相关的处理程序 } async reCreateUI(){ if(await gc_menu_friends_invite_ui.initUI(false) != false){ await gc_menu_friends_invite_ui.createUI(); } } async private_saveUIConfFile() { } async private_readUIConfFile() { } } //------------------------------------------------------------------------------------------------------------------------------------------------------------------- /** * UI类 - 已屏蔽 模块 UI具体实现 * @class * @classdesc UI类 - 已屏蔽 模块 UI具体实现 * @extends UI */ class menu_shielding_ui extends UI { constructor(arg) { super(); } async initUI(type) { //type: true: 第一次加载, false: 再加载 super.initUI(); // 设置数据库 // var db = new DB(); // db.Test(); // db.initAndCreateNewDBInstance({ // driver: [localforage.WEBSQL, // localforage.INDEXEDDB, // localforage.LOCALSTORAGE], // name: 'Steam assistant-Conf', // size: 10485760 //10mb // }); g_db = new DB({ //设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Conf', size: 10485760 //10mb },true); g_db1 = new DB({ //拓展功能 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Expand', size: 10485760 //10mb },false); g_db2 = new DB({ //动态助手 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Activity', size: 1073741824 //1gb },false); g_db3 = new DB({ //数据分析 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Friend', size: 1073741824 //1gb },false); g_db4 = new DB({ //留言设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Comment', size: 104857600 //100mb },false); await g_db.Write('g_conf',g_conf); //写入 await g_db.Write('g_uiConf',g_uiConf); //写入 //debugger //var data = await g_db.getAllKeyName(); //console.log("data",data); //var data = await g_db.getKeyNameByIndex(1); //console.log("data",data); //var data = await g_db.getLength(); //console.log("data",data); var data = await g_db.Read('g_conf'); //读取 console.log("data",data); var data = await g_db.Read('g_uiConf'); //读取 console.log("data",data); //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.Remove('g_conf'); //删除数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.RemoveAll(); //删除所有数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //if(data.length == 0){ // console.log("没有数据!"); //} if(getLoginStatus() == false){ //判断是否登录,如果没有登录则不需要继续运行 layer.alert('请先登录Steam,才能继续使用哦~', {icon: 0},function(index){ if(g_conf[0].autoLogin == 1){ var obj = document.getElementsByClassName("global_action_link"); for (let i = 0; i < obj.length; i++) { if(obj[i].className == "global_action_link"){ obj[i].click(); //跳转到登录页面 } } } }); return false; } readConfInfo(g_steamID); //读取已保存的对应配置信息 if(type){ //第一次加载才需要监听这些事件 //1.监听url中的hash变化 //window.location.hash='state_online' => https://steamcommunity.com/id/miku-39/friends#state_online //页面不刷新,url改变,定位到指定锚点 window.addEventListener('hashchange',function(event){ console.log("1.监听url中的hash变化" + event); isReCreateUi(); //是否重新创建Ui }); //2.监听通过history来改变url的事件 //浏览器前进,后退等 window.addEventListener('popstate', function(event) { console.log("2.监听通过history来改变url的事件" + event); isReCreateUi(); //是否重新创建Ui }); //3.监听pushState和replaceState行为 //pushState可以监听到本页替换超链接 var _wr = function(type) { var orig = history[type]; return function() { var rv = orig.apply(this, arguments); var e = new Event(type); e.arguments = arguments; window.dispatchEvent(e); return rv; }; }; history.pushState = _wr('pushState'); history.replaceState = _wr('replaceState'); window.addEventListener('replaceState', function(e) { console.log('监听到replaceState!'); isReCreateUi(); //是否重新创建Ui }); window.addEventListener('pushState', function(e) { console.log('监听到pushState!'); var url = window.location.origin + window.location.pathname; //window.location.href //去除参数和锚点后的url //https://steamcommunity.com/id/miku-39/friends?l=english#state_online => https://steamcommunity.com/id/miku-39/friends isReCreateUi(); //是否重新创建Ui }); } } async createUI() { super.createUI(); //正常html代码 jQuery("#manage_friends").after(mainUI_html); if(g_uiConf.isShowQuickNavigationBar){ //是否显示快速导航栏 //快捷导航栏 jQuery(".responsive_page_template_content").after(ExpandUI_QuickNavigationBar_html); } UI.prototype.uiHandler(); //UI与UI事件等相关的处理程序 } async reCreateUI(){ if(await gc_menu_shielding_ui.initUI(false) != false){ await gc_menu_shielding_ui.createUI(); } } async private_saveUIConfFile() { } async private_readUIConfFile() { } } //------------------------------------------------------------------------------------------------------------------------------------------------------------------- /** * @class * @classdesc UI类 - 共同游戏 模块 UI具体实现 * @extends UI */ class menu_gameFriend_ui extends UI { constructor(arg) { super(); } async initUI(type) { //type: true: 第一次加载, false: 再加载 super.initUI(); // 设置数据库 // var db = new DB(); // db.Test(); // db.initAndCreateNewDBInstance({ // driver: [localforage.WEBSQL, // localforage.INDEXEDDB, // localforage.LOCALSTORAGE], // name: 'Steam assistant-Conf', // size: 10485760 //10mb // }); g_db = new DB({ //设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Conf', size: 10485760 //10mb },true); g_db1 = new DB({ //拓展功能 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Expand', size: 10485760 //10mb },false); g_db2 = new DB({ //动态助手 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Activity', size: 1073741824 //1gb },false); g_db3 = new DB({ //数据分析 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Friend', size: 1073741824 //1gb },false); g_db4 = new DB({ //留言设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Comment', size: 104857600 //100mb },false); await g_db.Write('g_conf',g_conf); //写入 await g_db.Write('g_uiConf',g_uiConf); //写入 //debugger //var data = await g_db.getAllKeyName(); //console.log("data",data); //var data = await g_db.getKeyNameByIndex(1); //console.log("data",data); //var data = await g_db.getLength(); //console.log("data",data); var data = await g_db.Read('g_conf'); //读取 console.log("data",data); var data = await g_db.Read('g_uiConf'); //读取 console.log("data",data); //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.Remove('g_conf'); //删除数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.RemoveAll(); //删除所有数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //if(data.length == 0){ // console.log("没有数据!"); //} if(getLoginStatus() == false){ //判断是否登录,如果没有登录则不需要继续运行 layer.alert('请先登录Steam,才能继续使用哦~', {icon: 0},function(index){ if(g_conf[0].autoLogin == 1){ var obj = document.getElementsByClassName("global_action_link"); for (let i = 0; i < obj.length; i++) { if(obj[i].className == "global_action_link"){ obj[i].click(); //跳转到登录页面 } } } }); return false; } readConfInfo(g_steamID); //读取已保存的对应配置信息 if(type){ //第一次加载才需要监听这些事件 //1.监听url中的hash变化 //window.location.hash='state_online' => https://steamcommunity.com/id/miku-39/friends#state_online //页面不刷新,url改变,定位到指定锚点 window.addEventListener('hashchange',function(event){ console.log("1.监听url中的hash变化" + event); isReCreateUi(); //是否重新创建Ui }); //2.监听通过history来改变url的事件 //浏览器前进,后退等 window.addEventListener('popstate', function(event) { console.log("2.监听通过history来改变url的事件" + event); isReCreateUi(); //是否重新创建Ui }); //3.监听pushState和replaceState行为 //pushState可以监听到本页替换超链接 var _wr = function(type) { var orig = history[type]; return function() { var rv = orig.apply(this, arguments); var e = new Event(type); e.arguments = arguments; window.dispatchEvent(e); return rv; }; }; history.pushState = _wr('pushState'); history.replaceState = _wr('replaceState'); window.addEventListener('replaceState', function(e) { console.log('监听到replaceState!'); isReCreateUi(); //是否重新创建Ui }); window.addEventListener('pushState', function(e) { console.log('监听到pushState!'); var url = window.location.origin + window.location.pathname; //window.location.href //去除参数和锚点后的url //https://steamcommunity.com/id/miku-39/friends?l=english#state_online => https://steamcommunity.com/id/miku-39/friends isReCreateUi(); //是否重新创建Ui }); } } async createUI() { super.createUI(); //正常html代码 jQuery("#manage_friends").after(mainUI_html); if(g_uiConf.isShowQuickNavigationBar){ //是否显示快速导航栏 //快捷导航栏 jQuery(".responsive_page_template_content").after(ExpandUI_QuickNavigationBar_html); } UI.prototype.uiHandler(); //UI与UI事件等相关的处理程序 } async reCreateUI(){ if(await gc_menu_gameFriend_ui.initUI(false) != false){ await gc_menu_gameFriend_ui.createUI(); } } async private_saveUIConfFile() { } async private_readUIConfFile() { } } //------------------------------------------------------------------------------------------------------------------------------------------------------------------- /** * UI类 - 直播版主 模块 UI具体实现 * @class * @classdesc UI类 - 直播版主 模块 UI具体实现 * @extends UI */ class menu_liveAdmin_ui extends UI { constructor(arg) { super(); } async initUI(type) { //type: true: 第一次加载, false: 再加载 super.initUI(); // 设置数据库 // var db = new DB(); // db.Test(); // db.initAndCreateNewDBInstance({ // driver: [localforage.WEBSQL, // localforage.INDEXEDDB, // localforage.LOCALSTORAGE], // name: 'Steam assistant-Conf', // size: 10485760 //10mb // }); g_db = new DB({ //设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Conf', size: 10485760 //10mb },true); g_db1 = new DB({ //拓展功能 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Expand', size: 10485760 //10mb },false); g_db2 = new DB({ //动态助手 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Activity', size: 1073741824 //1gb },false); g_db3 = new DB({ //数据分析 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Friend', size: 1073741824 //1gb },false); g_db4 = new DB({ //留言设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Comment', size: 104857600 //100mb },false); await g_db.Write('g_conf',g_conf); //写入 await g_db.Write('g_uiConf',g_uiConf); //写入 //debugger //var data = await g_db.getAllKeyName(); //console.log("data",data); //var data = await g_db.getKeyNameByIndex(1); //console.log("data",data); //var data = await g_db.getLength(); //console.log("data",data); var data = await g_db.Read('g_conf'); //读取 console.log("data",data); var data = await g_db.Read('g_uiConf'); //读取 console.log("data",data); //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.Remove('g_conf'); //删除数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.RemoveAll(); //删除所有数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //if(data.length == 0){ // console.log("没有数据!"); //} if(getLoginStatus() == false){ //判断是否登录,如果没有登录则不需要继续运行 layer.alert('请先登录Steam,才能继续使用哦~', {icon: 0},function(index){ if(g_conf[0].autoLogin == 1){ var obj = document.getElementsByClassName("global_action_link"); for (let i = 0; i < obj.length; i++) { if(obj[i].className == "global_action_link"){ obj[i].click(); //跳转到登录页面 } } } }); return false; } readConfInfo(g_steamID); //读取已保存的对应配置信息 if(type){ //第一次加载才需要监听这些事件 //1.监听url中的hash变化 //window.location.hash='state_online' => https://steamcommunity.com/id/miku-39/friends#state_online //页面不刷新,url改变,定位到指定锚点 window.addEventListener('hashchange',function(event){ console.log("1.监听url中的hash变化" + event); isReCreateUi(); //是否重新创建Ui }); //2.监听通过history来改变url的事件 //浏览器前进,后退等 window.addEventListener('popstate', function(event) { console.log("2.监听通过history来改变url的事件" + event); isReCreateUi(); //是否重新创建Ui }); //3.监听pushState和replaceState行为 //pushState可以监听到本页替换超链接 var _wr = function(type) { var orig = history[type]; return function() { var rv = orig.apply(this, arguments); var e = new Event(type); e.arguments = arguments; window.dispatchEvent(e); return rv; }; }; history.pushState = _wr('pushState'); history.replaceState = _wr('replaceState'); window.addEventListener('replaceState', function(e) { console.log('监听到replaceState!'); isReCreateUi(); //是否重新创建Ui }); window.addEventListener('pushState', function(e) { console.log('监听到pushState!'); var url = window.location.origin + window.location.pathname; //window.location.href //去除参数和锚点后的url //https://steamcommunity.com/id/miku-39/friends?l=english#state_online => https://steamcommunity.com/id/miku-39/friends isReCreateUi(); //是否重新创建Ui }); } } async createUI() { super.createUI(); //正常html代码 jQuery("#manage_friends").after(mainUI_html); if(g_uiConf.isShowQuickNavigationBar){ //是否显示快速导航栏 //快捷导航栏 jQuery(".responsive_page_template_content").after(ExpandUI_QuickNavigationBar_html); } UI.prototype.uiHandler(); //UI与UI事件等相关的处理程序 } async reCreateUI(){ if(await gc_menu_liveAdmin_ui.initUI(false) != false){ await gc_menu_liveAdmin_ui.createUI(); } } async private_saveUIConfFile() { } async private_readUIConfFile() { } } //------------------------------------------------------------------------------------------------------------------------------------------------------------------- /** * UI类 - 关注的玩家 模块 UI具体实现 * @class * @classdesc UI类 - 关注的玩家 模块 UI具体实现 * @extends UI */ class menu_following_Players_ui extends UI { constructor(arg) { super(); } async initUI(type) { //type: true: 第一次加载, false: 再加载 super.initUI(); // 设置数据库 // var db = new DB(); // db.Test(); // db.initAndCreateNewDBInstance({ // driver: [localforage.WEBSQL, // localforage.INDEXEDDB, // localforage.LOCALSTORAGE], // name: 'Steam assistant-Conf', // size: 10485760 //10mb // }); g_db = new DB({ //设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Conf', size: 10485760 //10mb },true); g_db1 = new DB({ //拓展功能 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Expand', size: 10485760 //10mb },false); g_db2 = new DB({ //动态助手 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Activity', size: 1073741824 //1gb },false); g_db3 = new DB({ //数据分析 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Friend', size: 1073741824 //1gb },false); g_db4 = new DB({ //留言设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Comment', size: 104857600 //100mb },false); await g_db.Write('g_conf',g_conf); //写入 await g_db.Write('g_uiConf',g_uiConf); //写入 //debugger //var data = await g_db.getAllKeyName(); //console.log("data",data); //var data = await g_db.getKeyNameByIndex(1); //console.log("data",data); //var data = await g_db.getLength(); //console.log("data",data); var data = await g_db.Read('g_conf'); //读取 console.log("data",data); var data = await g_db.Read('g_uiConf'); //读取 console.log("data",data); //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.Remove('g_conf'); //删除数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.RemoveAll(); //删除所有数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //if(data.length == 0){ // console.log("没有数据!"); //} if(getLoginStatus() == false){ //判断是否登录,如果没有登录则不需要继续运行 layer.alert('请先登录Steam,才能继续使用哦~', {icon: 0},function(index){ if(g_conf[0].autoLogin == 1){ var obj = document.getElementsByClassName("global_action_link"); for (let i = 0; i < obj.length; i++) { if(obj[i].className == "global_action_link"){ obj[i].click(); //跳转到登录页面 } } } }); return false; } readConfInfo(g_steamID); //读取已保存的对应配置信息 if(type){ //第一次加载才需要监听这些事件 //1.监听url中的hash变化 //window.location.hash='state_online' => https://steamcommunity.com/id/miku-39/friends#state_online //页面不刷新,url改变,定位到指定锚点 window.addEventListener('hashchange',function(event){ console.log("1.监听url中的hash变化" + event); isReCreateUi(); //是否重新创建Ui }); //2.监听通过history来改变url的事件 //浏览器前进,后退等 window.addEventListener('popstate', function(event) { console.log("2.监听通过history来改变url的事件" + event); isReCreateUi(); //是否重新创建Ui }); //3.监听pushState和replaceState行为 //pushState可以监听到本页替换超链接 var _wr = function(type) { var orig = history[type]; return function() { var rv = orig.apply(this, arguments); var e = new Event(type); e.arguments = arguments; window.dispatchEvent(e); return rv; }; }; history.pushState = _wr('pushState'); history.replaceState = _wr('replaceState'); window.addEventListener('replaceState', function(e) { console.log('监听到replaceState!'); isReCreateUi(); //是否重新创建Ui }); window.addEventListener('pushState', function(e) { console.log('监听到pushState!'); var url = window.location.origin + window.location.pathname; //window.location.href //去除参数和锚点后的url //https://steamcommunity.com/id/miku-39/friends?l=english#state_online => https://steamcommunity.com/id/miku-39/friends isReCreateUi(); //是否重新创建Ui }); } } async createUI() { super.createUI(); //正常html代码 jQuery("#manage_friends").after(mainUI_html); if(g_uiConf.isShowQuickNavigationBar){ //是否显示快速导航栏 //快捷导航栏 jQuery(".responsive_page_template_content").after(ExpandUI_QuickNavigationBar_html); } UI.prototype.uiHandler(); //UI与UI事件等相关的处理程序 } async reCreateUI(){ if(await gc_menu_following_Players_ui.initUI(false) != false){ await gc_menu_following_Players_ui.createUI(); } } async private_saveUIConfFile() { } async private_readUIConfFile() { } } //------------------------------------------------------------------------------------------------------------------------------------------------------------------- /** * UI类 - 您的组 模块 UI具体实现 * @class * @classdesc UI类 - 您的组 模块 UI具体实现 * @extends UI */ // var DOMPurify = function DOMPurify(root) { // return createDOMPurify(root); // }; // var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; // // Most of the code here comes from dselect.js // class Sortbox { // static init() { // this._activeDropLists = {}; // this._lastSelectHideTime = 0; // document.addEventListener("mousedown", e => this._handleMouseClick(e)); // } // static _handleMouseClick(e) { // for (let key of Object.keys(this._activeDropLists)) { // if (!this._activeDropLists[key]) continue; // let ulAboveEvent = e.target.closest("ul"); // if (ulAboveEvent && ulAboveEvent.id === `${key}_droplist`) continue; // this._hide(key); // } // } // static _highlightItem(id, index, bSetSelected) { // let droplist = document.querySelector(`#${id}_droplist`); // let trigger = document.querySelector(`#${id}_trigger`); // let rgItems = droplist.getElementsByTagName("a"); // if (index >= 0 && index < rgItems.length ) { // let item = rgItems[index]; // if (typeof trigger.highlightedItem !== "undefined" && trigger.highlightedItem !== index) // rgItems[trigger.highlightedItem].className = "inactive_selection"; // trigger.highlightedItem = index; // rgItems[index].className = "highlighted_selection"; // let yOffset = rgItems[index].offsetTop + rgItems[index].clientHeight; // let curVisibleOffset = droplist.scrollTop + droplist.clientHeight; // let bScrolledDown = false; // let nMaxLoopIterations = rgItems.length; // let nLoopCounter = 0; // while (curVisibleOffset < yOffset && nLoopCounter++ < nMaxLoopIterations) { // droplist.scrollTop += rgItems[index].clientHeight; // curVisibleOffset = droplist.scrollTop+droplist.clientHeight; // bScrolledDown = true; // } // if ( !bScrolledDown ) { // nLoopCounter = 0; // yOffset = rgItems[index].offsetTop; // curVisibleOffset = droplist.scrollTop; // while(curVisibleOffset > yOffset && nLoopCounter++ < nMaxLoopIterations) { // droplist.scrollTop -= rgItems[index].clientHeight; // curVisibleOffset = droplist.scrollTop; // } // } // if (bSetSelected) { // HTML.inner(trigger, item.innerHTML); // let input = document.querySelector(`#${id}`); // input.value = item.id; // input.dispatchEvent(new Event("change")); // this._hide(id); // } // } // } // static _onFocus(id) { // this._activeDropLists[id] = true; // } // static _onBlur(id) { // if (!this._classCheck(document.querySelector(`#${id}_trigger`), "activetrigger")) // this._activeDropLists[id] = false; // } // static _hide(id) { // let droplist = document.querySelector(`#${id}_droplist`); // let trigger = document.querySelector(`#${id}_trigger`); // let d = new Date(); // this._lastSelectHideTime = d.valueOf(); // trigger.className = "trigger"; // droplist.className = "dropdownhidden"; // this._activeDropLists[id] = false; // trigger.focus(); // } // static _show(id) { // let d = new Date(); // if (d - this._lastSelectHideTime < 50) return; // let droplist = document.querySelector(`#${id}_droplist`); // let trigger = document.querySelector(`#${id}_trigger`); // trigger.className = "activetrigger"; // droplist.className = "dropdownvisible"; // this._activeDropLists[id] = true; // trigger.focus(); // } // static _onTriggerClick(id) { // if (!this._classCheck(document.querySelector(`#${id}_trigger`), "activetrigger")) { // this._show(id); // } // } // static _classCheck(element, className) { // return new RegExp(`\\b${className}\\b`).test(element.className); // } // /** // * NOTE FOR ADDON REVIEWER: // * Elements returned by this function are already sanitized (calls to HTML class), // * so they can be safely inserted without being sanitized again. // * If we would sanitize them again, all event listeners would be lost due to // * DOMPurify only returning HTML strings. // */ // static get(name, options, initialOption, changeFn, storageOption) { // let id = `sort_by_${name}`; // let reversed = initialOption.endsWith("_DESC"); // let arrowDown = "↓"; // let arrowUp = "↑"; // let box = HTML.element( // `<div class="es-sortbox es-sortbox--${name}"> // <div class="es-sortbox__label">${Localization.str.sort_by}</div> // <div class="es-sortbox__container"> // <input id="${id}" type="hidden" name="${name}" value="${initialOption}"> // <a class="trigger" id="${id}_trigger"></a> // <div class="es-dropdown"> // <ul id="${id}_droplist" class="es-dropdown__list dropdownhidden"></ul> // </div> // </div> // <span class="es-sortbox__reverse">${arrowDown}</span> // </div>`); // let input = box.querySelector(`#${id}`); // input.addEventListener("change", function() { onChange(this.value.replace(`${id}_`, ''), reversed); }); // // Trigger changeFn for initial option // if (initialOption !== "default_ASC") { // input.dispatchEvent(new Event("change")); // } // let reverseEl = box.querySelector(".es-sortbox__reverse"); // reverseEl.addEventListener("click", () => { // reversed = !reversed; // reverseEl.textContent = reversed ? arrowUp : arrowDown; // onChange(input.value.replace(`${id}_`, ''), reversed); // }); // if (reversed) reverseEl.textContent = arrowUp; // let trigger = box.querySelector(`#${id}_trigger`); // trigger.addEventListener("focus", () => this._onFocus(id)); // trigger.addEventListener("blur", () => this._onBlur(id)); // trigger.addEventListener("click", () => this._onTriggerClick(id)); // let ul = box.querySelector("ul"); // let trimmedOption = getTrimmedValue(initialOption); // for (let i = 0; i < options.length; ++i) { // let [key, text] = options[i]; // let toggle = "inactive"; // if (key === trimmedOption) { // box.querySelector(`#${id}`).value = key; // box.querySelector(".trigger").textContent = text; // toggle = "highlighted"; // } // HTML.beforeEnd(ul, // `<li> // <a class="${toggle}_selection" tabindex="99999" id="${id}_${key}">${text}</a> // </li>`); // let a = ul.querySelector("li:last-child > a"); // //a.href = "javascript:DSelectNoop()"; // a.addEventListener("mouseover", () => this._highlightItem(id, i, false)); // a.addEventListener("click", () => this._highlightItem(id, i, true)); // } // function getTrimmedValue(val) { return val.replace(/(_ASC|_DESC)$/, ''); } // function onChange(val, reversed) { // val = getTrimmedValue(val); // changeFn(val, reversed); // if (storageOption) { SyncedStorage.set(storageOption, `${val}_${reversed ? "DESC" : "ASC"}`); } // } // return box; // } // } // DOMPurify.sanitize = function (dirty, cfg) { // var body = void 0; // var importedNode = void 0; // var currentNode = void 0; // var oldNode = void 0; // var returnNode = void 0; // /* Make sure we have a string to sanitize. // DO NOT return early, as this will return the wrong type if // the user has requested a DOM object rather than a string */ // if (!dirty) { // dirty = '<!-->'; // } // /* Stringify, in case dirty is an object */ // if (typeof dirty !== 'string' && !_isNode(dirty)) { // // eslint-disable-next-line no-negated-condition // if (typeof dirty.toString !== 'function') { // throw new TypeError('toString is not a function'); // } else { // dirty = dirty.toString(); // if (typeof dirty !== 'string') { // throw new TypeError('dirty is not a string, aborting'); // } // } // } // /* Check we can run. Otherwise fall back or ignore */ // if (!DOMPurify.isSupported) { // if (_typeof(window.toStaticHTML) === 'object' || typeof window.toStaticHTML === 'function') { // if (typeof dirty === 'string') { // return window.toStaticHTML(dirty); // } // if (_isNode(dirty)) { // return window.toStaticHTML(dirty.outerHTML); // } // } // return dirty; // } // /* Assign config vars */ // if (!SET_CONFIG) { // _parseConfig(cfg); // } // /* Clean up removed elements */ // DOMPurify.removed = []; // if (IN_PLACE) { // /* No special handling necessary for in-place sanitization */ // } else if (dirty instanceof Node) { // /* If dirty is a DOM element, append to an empty document to avoid // elements being stripped by the parser */ // body = _initDocument('<!-->'); // importedNode = body.ownerDocument.importNode(dirty, true); // if (importedNode.nodeType === 1 && importedNode.nodeName === 'BODY') { // /* Node is already a body, use as is */ // body = importedNode; // } else { // // eslint-disable-next-line unicorn/prefer-node-append // body.appendChild(importedNode); // } // } else { // /* Exit directly if we have nothing to do */ // if (!RETURN_DOM && !SAFE_FOR_TEMPLATES && !WHOLE_DOCUMENT && dirty.indexOf('<') === -1) { // return trustedTypesPolicy ? trustedTypesPolicy.createHTML(dirty) : dirty; // } // /* Initialize the document to work on */ // body = _initDocument(dirty); // /* Check we have a DOM node from the data */ // if (!body) { // return RETURN_DOM ? null : emptyHTML; // } // } // /* Remove first element node (ours) if FORCE_BODY is set */ // if (body && FORCE_BODY) { // _forceRemove(body.firstChild); // } // /* Get node iterator */ // var nodeIterator = _createIterator(IN_PLACE ? dirty : body); // /* Now start iterating over the created document */ // while (currentNode = nodeIterator.nextNode()) { // /* Fix IE's strange behavior with manipulated textNodes #89 */ // if (currentNode.nodeType === 3 && currentNode === oldNode) { // continue; // } // /* Sanitize tags and elements */ // if (_sanitizeElements(currentNode)) { // continue; // } // /* Shadow DOM detected, sanitize it */ // if (currentNode.content instanceof DocumentFragment) { // _sanitizeShadowDOM(currentNode.content); // } // /* Check attributes, sanitize if necessary */ // _sanitizeAttributes(currentNode); // oldNode = currentNode; // } // oldNode = null; // /* If we sanitized `dirty` in-place, return it. */ // if (IN_PLACE) { // return dirty; // } // /* Return sanitized string or DOM */ // if (RETURN_DOM) { // if (RETURN_DOM_FRAGMENT) { // returnNode = createDocumentFragment.call(body.ownerDocument); // while (body.firstChild) { // // eslint-disable-next-line unicorn/prefer-node-append // returnNode.appendChild(body.firstChild); // } // } else { // returnNode = body; // } // if (RETURN_DOM_IMPORT) { // /* AdoptNode() is not used because internal state is not reset // (e.g. the past names map of a HTMLFormElement), this is safe // in theory but we would rather not risk another attack vector. // The state that is cloned by importNode() is explicitly defined // by the specs. */ // returnNode = importNode.call(originalDocument, returnNode, true); // } // return returnNode; // } // var serializedHTML = WHOLE_DOCUMENT ? body.outerHTML : body.innerHTML; // /* Sanitize final string template-safe */ // if (SAFE_FOR_TEMPLATES) { // serializedHTML = serializedHTML.replace(MUSTACHE_EXPR$$1, ' '); // serializedHTML = serializedHTML.replace(ERB_EXPR$$1, ' '); // } // return trustedTypesPolicy ? trustedTypesPolicy.createHTML(serializedHTML) : serializedHTML; // }; // class HTML { // static escape(str) { // // @see https://stackoverflow.com/a/4835406 // let map = { // '&': '&', // '<': '<', // '>': '>', // '"': '"', // "'": ''' // }; // return str.replace(/[&<>"']/g, function(m) { return map[m]; }); // } // static fragment(html) { // let template = document.createElement('template'); // template.innerHTML = DOMPurify.sanitize(html); // return template.content; // } // static element(html) { // return HTML.fragment(html).firstElementChild; // } // static inner(node, html) { // if (typeof node == 'undefined' || node === null) { // console.warn(`${node} is not an Element.`); // return null; // } // if (typeof node == "string") { // node = document.querySelector(node); // } // if (!(node instanceof Element)) { // console.warn(`${node} is not an Element.`); // return null; // } // node.innerHTML = DOMPurify.sanitize(html); // return node; // } // static replace(node, html) { // if (typeof node == 'undefined' || node === null) { // console.warn(`${node} is not an Element.`); // return null; // } // if (typeof node == "string") { // node = document.querySelector(node); // } // if (!(node instanceof Element)) { // console.warn(`${node} is not an Element.`); // return null; // } // node.outerHTML = DOMPurify.sanitize(html); // return node; // } // static wrap(node, html) { // if (typeof node == 'undefined' || node === null) { // console.warn(`${node} is not an Element.`); // return null; // } // if (typeof node == "string") { // node = document.querySelector(node); // } // if (!(node instanceof Element)) { // console.warn(`${node} is not an Element.`); // return null; // } // let wrapper = HTML.element(html); // node.replaceWith(wrapper); // wrapper.append(node); // return wrapper; // } // static adjacent(node, position, html) { // if (typeof node == 'undefined' || node === null) { // console.warn(`${node} is not an Element.`); // return null; // } // if (typeof node == "string") { // node = document.querySelector(node); // } // if (!(node instanceof Element)) { // console.warn(`${node} is not an Element.`); // return null; // } // node.insertAdjacentHTML(position, DOMPurify.sanitize(html)); // return node; // } // static beforeBegin(node, html) { // HTML.adjacent(node, "beforebegin", html); // } // static afterBegin(node, html) { // HTML.adjacent(node, "afterbegin", html); // } // static beforeEnd(node, html) { // HTML.adjacent(node, "beforeend", html); // } // static afterEnd(node, html) { // HTML.adjacent(node, "afterend", html); // } // } // class GroupsPageClass { // constructor() { // this._groups = Array.from(document.querySelectorAll(".group_block")); // this._initSort = true; // this._moveSearchBar(); // this._addSort(); // this._addManageBtn(); // } // _moveSearchBar() { // // move the search bar to the same position as on friends page // let container = HTML.wrap("#search_text_box", '<div class="searchBarContainer"></div>'); // document.querySelector("#search_results").insertAdjacentElement("beforebegin", container); // } // _addSort() { // document.querySelector("span.profile_groups.title").insertAdjacentElement("afterend", Sortbox.get( // "groups", // [ // ["default", Localization.str.theworddefault], // ["members", Localization.str.members], // ["names", Localization.str.name] // ], // SyncedStorage.get("sortgroupsby"), // (sortBy, reversed) => { this._sortGroups(sortBy, reversed) }, // "sortgroupsby") // ); // let sortbox = document.querySelector("div.es-sortbox"); // sortbox.style.flexGrow = "2"; // sortbox.style.marginRight = "20px"; // sortbox.style.marginTop = "0"; // sortbox.style.textAlign = "right"; // } // _getSortFunc(sortBy) { // let property = `esSort${sortBy}`; // switch(sortBy) { // case "default": // return (a, b) => Number(a.dataset[property]) - Number(b.dataset[property]); // case "members": // return (a, b) => Number(b.dataset[property]) - Number(a.dataset[property]); // case "names": // return (a, b) => a.dataset[property].localeCompare(b.dataset[property]); // } // } // _sortGroups(sortBy, reversed) { // if (this._groups.length === 0) { return; } // if (this._initSort) { // let i = 0; // for (let group of this._groups) { // let name = group.querySelector(".groupTitle > a").textContent; // let membercount = Number(group.querySelector(".memberRow > a").textContent.match(/\d+/g).join("")); // group.dataset.esSortdefault = i.toString(); // group.dataset.esSortnames = name; // group.dataset.esSortmembers = membercount.toString(); // i++; // } // this._initSort = false; // } // this._groups.sort(this._getSortFunc(sortBy, `esSort${sortBy}`)); // let searchResults = document.querySelector("#search_results_empty"); // for (let group of this._groups) { // if (reversed) { // searchResults.insertAdjacentElement("afterend", group); // } else { // searchResults.parentElement.appendChild(group); // } // } // } // _addManageBtn() { // if (this._groups.length === 0) { return; } // if (!this._groups[0].querySelector(".actions")) { return; } // let groupsStr = Localization.str.groups; // HTML.beforeEnd(".title_bar", // `<button id="manage_friends_control" class="profile_friends manage_link btnv6_blue_hoverfade btn_medium btn_uppercase"> // <span>${groupsStr.manage_groups}</span> // </button>`); // HTML.afterEnd(".title_bar", // `<div id="manage_friends" class="manage_friends_panel"> // <div class="row">${groupsStr.action_groups} // <span class="row"> // <span class="dimmed">${groupsStr.select}</span> // <span class="selection_type" id="es_select_all">${Localization.str.all}</span> // <span class="selection_type" id="es_select_none">${Localization.str.none}</span> // <span class="selection_type" id="es_select_inverse">${Localization.str.inverse}</span> // </span> // </div> // <div class="row"> // <span class="manage_action anage_action btnv6_lightblue_blue btn_medium btn_uppercase" id="es_leave_groups"> // <span>${groupsStr.leave}</span> // </span> // <span id="selected_msg_err" class="selected_msg error hidden"></span> // <span id="selected_msg" class="selected_msg hidden">${groupsStr.selected.replace("__n__", `<span id="selected_count"></span>`)}</span> // </div> // <div class="row"></div> // </div>`); // for (let group of this._groups) { // group.classList.add("selectable"); // HTML.afterBegin(group, // `<div class="indicator select_friend"> // <input class="select_friend_checkbox" type="checkbox"> // </div>`); // group.querySelector(".select_friend").addEventListener("click", () => { // group.classList.toggle("selected"); // group.querySelector(".select_friend_checkbox").checked = group.classList.contains("selected"); // ExtensionLayer.runInPageContext(() => { UpdateSelection(); }); // }); // } // document.querySelector("#manage_friends_control").addEventListener("click", () => { // ExtensionLayer.runInPageContext(() => { ToggleManageFriends(); }); // }); // document.querySelector("#es_select_all").addEventListener("click", () => { // ExtensionLayer.runInPageContext(() => { SelectAll(); }); // }); // document.querySelector("#es_select_none").addEventListener("click", () => { // ExtensionLayer.runInPageContext(() => { SelectNone(); }); // }); // document.querySelector("#es_select_inverse").addEventListener("click", () => { // ExtensionLayer.runInPageContext(() => { SelectInverse(); }); // }); // document.querySelector("#es_leave_groups").addEventListener("click", () => this._leaveGroups()); // }; // async _leaveGroups() { // let selected = []; // for (let group of this._groups) { // if (!group.classList.contains("selected")) { // continue; // } // let actions = group.querySelector(".actions"); // let admin = actions.querySelector("[href*='/edit']"); // let split = actions.querySelector("[onclick*=ConfirmLeaveGroup]") // .getAttribute("onclick").split(/'|"/); // let id = split[1]; // if (admin) { // let name = split[3]; // let body = Localization.str.groups.leave_admin_confirm.replace("__name__", `<a href=\\"/gid/${id}\\" target=\\"_blank\\">${name}</a>`); // let result = await ConfirmDialog.open(Localization.str.groups.leave, body); // let cont = (result === "OK"); // if (!cont) { // group.querySelector(".select_friend").click(); // continue; // } // } // selected.push([id, group]); // } // if (selected.length > 0) { // let body = Localization.str.groups.leave_groups_confirm.replace("__n__", selected.length); // let result = await ConfirmDialog.open(Localization.str.groups.leave, body); // if (result === "OK") { // for (let tuple of selected) { // let [id, group] = tuple; // let res = await this._leaveGroup(id).catch(err => console.error(err)); // if (!res || !res.success) { // console.error("Failed to leave group " + id); // continue; // } // group.style.opacity = "0.3"; // group.querySelector(".select_friend").click(); // } // } // } // } // _leaveGroup(id) { // let formData = new FormData(); // formData.append("sessionid", User.getSessionId()); // formData.append("steamid", User.steamId); // formData.append("ajax", 1); // formData.append("action", "leave_group"); // formData.append("steamids[]", id); // return RequestData.post(User.profileUrl + "/friends/action", formData, { // withCredentials: true // }, "json"); // } // } class menu_groups_ui extends UI { constructor(arg) { super(); } async initUI(type) { //type: true: 第一次加载, false: 再加载 super.initUI(); // 设置数据库 // var db = new DB(); // db.Test(); // db.initAndCreateNewDBInstance({ // driver: [localforage.WEBSQL, // localforage.INDEXEDDB, // localforage.LOCALSTORAGE], // name: 'Steam assistant-Conf', // size: 10485760 //10mb // }); g_db = new DB({ //设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Conf', size: 10485760 //10mb },true); g_db1 = new DB({ //拓展功能 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Expand', size: 10485760 //10mb },false); g_db2 = new DB({ //动态助手 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Activity', size: 1073741824 //1gb },false); g_db3 = new DB({ //数据分析 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Friend', size: 1073741824 //1gb },false); g_db4 = new DB({ //留言设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Comment', size: 104857600 //100mb },false); await g_db.Write('g_conf',g_conf); //写入 await g_db.Write('g_uiConf',g_uiConf); //写入 //debugger //var data = await g_db.getAllKeyName(); //console.log("data",data); //var data = await g_db.getKeyNameByIndex(1); //console.log("data",data); //var data = await g_db.getLength(); //console.log("data",data); var data = await g_db.Read('g_conf'); //读取 console.log("data",data); var data = await g_db.Read('g_uiConf'); //读取 console.log("data",data); //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.Remove('g_conf'); //删除数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.RemoveAll(); //删除所有数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //if(data.length == 0){ // console.log("没有数据!"); //} if(getLoginStatus() == false){ //判断是否登录,如果没有登录则不需要继续运行 layer.alert('请先登录Steam,才能继续使用哦~', {icon: 0},function(index){ if(g_conf[0].autoLogin == 1){ var obj = document.getElementsByClassName("global_action_link"); for (let i = 0; i < obj.length; i++) { if(obj[i].className == "global_action_link"){ obj[i].click(); //跳转到登录页面 } } } }); return false; } readConfInfo(g_steamID); //读取已保存的对应配置信息 if(type){ //第一次加载才需要监听这些事件 //1.监听url中的hash变化 //window.location.hash='state_online' => https://steamcommunity.com/id/miku-39/friends#state_online //页面不刷新,url改变,定位到指定锚点 window.addEventListener('hashchange',function(event){ console.log("1.监听url中的hash变化" + event); isReCreateUi(); //是否重新创建Ui }); //2.监听通过history来改变url的事件 //浏览器前进,后退等 window.addEventListener('popstate', function(event) { console.log("2.监听通过history来改变url的事件" + event); isReCreateUi(); //是否重新创建Ui }); //3.监听pushState和replaceState行为 //pushState可以监听到本页替换超链接 var _wr = function(type) { var orig = history[type]; return function() { var rv = orig.apply(this, arguments); var e = new Event(type); e.arguments = arguments; window.dispatchEvent(e); return rv; }; }; history.pushState = _wr('pushState'); history.replaceState = _wr('replaceState'); window.addEventListener('replaceState', function(e) { console.log('监听到replaceState!'); isReCreateUi(); //是否重新创建Ui }); window.addEventListener('pushState', function(e) { console.log('监听到pushState!'); var url = window.location.origin + window.location.pathname; //window.location.href //去除参数和锚点后的url //https://steamcommunity.com/id/miku-39/friends?l=english#state_online => https://steamcommunity.com/id/miku-39/friends isReCreateUi(); //是否重新创建Ui }); } } async createUI() { super.createUI(); //修改html代码并注册事件,使点击后和刷新后的ui都保持一致 //jQuery(".profile_groups.title_bar").remove(); //删除 // jQuery("#groups_list").prepend('\ // <div class="profile_groups title_bar">\ // <span class="profile_groups title">您的组</span>\ // <div class="es-sortbox es-sortbox--groups" style="flex-grow: 2; margin-right: 20px; margin-top: 0px; text-align: right;">\ // <div class="es-sortbox__label">排序依据:</div>\ // <div class="es-sortbox__container">\ // <input value="default" name="groups" type="hidden" id="sort_by_groups">\ // <a id="sort_by_groups_trigger" class="trigger">默认</a>\ // <div class="es-dropdown">\ // <ul class="es-dropdown__list dropdownhidden" id="sort_by_groups_droplist">\ // <li><a id="sort_by_groups_default" tabindex="99999" class="highlighted_selection">默认</a></li>\ // <li><a id="sort_by_groups_members" tabindex="99999" class="inactive_selection">成员</a></li>\ // <li><a id="sort_by_groups_names" tabindex="99999" class="inactive_selection">名称</a></li>\ // </ul>\ // </div>\ // </div>\ // <span class="es-sortbox__reverse">↓</span>\ // </div>\ // <button class="profile_friends manage_link btnv6_blue_hoverfade btn_medium btn_uppercase" id="manage_friends_control">\ // <span>管理组1</span>\ // </button>\ // </div>\ // \ // <div class="manage_friends_panel" id="manage_friends">\ // <div class="row">请在下方选择您要操作的组。\ // <span class="row">\ // <span class="dimmed">选择:</span>\ // <span id="es_select_all" class="selection_type">全部</span>\ // <span id="es_select_none" class="selection_type">无</span>\ // <span id="es_select_inverse" class="selection_type">逆序</span>\ // </span>\ // </div>\ // <div class="row">\ // <span id="es_leave_groups" class="manage_action anage_action btnv6_lightblue_blue btn_medium btn_uppercase">\ // <span>离开组</span>\ // </span>\ // <span class="selected_msg error hidden" id="selected_msg_err"></span>\ // <span class="selected_msg hidden" id="selected_msg">已选择 <span id="selected_count"></span> 个。</span>\ // </div>\ // <div class="row"></div>\ // </div>\ // \ // <div class="searchBarContainer">\ // <input name="search_text_box" id="search_text_box" class="groups_search_text_box" value="" onkeyup="ShowMatching( \'search_results\', \'group_block\', \'data-search\', $J(\'#search_text_box\').val(), UpdateGroupList );" autocomplete="off" autofocus="" placeholder="通过名称搜索组1">\ // </div>\ // </div>\ // '); //正常html代码 jQuery("#manage_friends").after(groupUI_html); // document.querySelector("#manage_friends_control").addEventListener("click", () => { // ToggleManageFriends(); // var obj = jQuery(".group_block.invite_row"); // if(obj.hasClass("manage")){ // obj.removeClass("selectable"); // obj.removeClass("manage"); // } // else{ // obj.addClass("selectable"); // obj.addClass("manage"); // } // }); // document.querySelector("#es_select_all").addEventListener("click", () => { // SelectAll(); // }); // document.querySelector("#es_select_none").addEventListener("click", () => { // SelectNone(); // }); // document.querySelector("#es_select_inverse").addEventListener("click", () => { // SelectInverse(); // }); //document.querySelector("#es_leave_groups").addEventListener("click", () => this._leaveGroups()); //(new GroupsPageClass()); if(g_uiConf.isShowQuickNavigationBar){ //是否显示快速导航栏 //快捷导航栏 jQuery(".responsive_page_template_content").after(ExpandUI_QuickNavigationBar_html); } UI.prototype.uiHandler(); //UI与UI事件等相关的处理程序 } async reCreateUI(){ if(await gc_menu_groups_ui.initUI(false) != false){ await gc_menu_groups_ui.createUI(); } } async private_saveUIConfFile() { } async private_readUIConfFile() { } } //------------------------------------------------------------------------------------------------------------------------------------------------------------------- /** * UI类 - 组邀请 模块 UI具体实现 * @class * @classdesc UI类 - 组邀请 模块 UI具体实现 * @extends UI */ class menu_groups_invite_ui extends UI { constructor(arg) { super(); } async initUI(type) { //type: true: 第一次加载, false: 再加载 super.initUI(); // 设置数据库 // var db = new DB(); // db.Test(); // db.initAndCreateNewDBInstance({ // driver: [localforage.WEBSQL, // localforage.INDEXEDDB, // localforage.LOCALSTORAGE], // name: 'Steam assistant-Conf', // size: 10485760 //10mb // }); g_db = new DB({ //设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Conf', size: 10485760 //10mb },true); g_db1 = new DB({ //拓展功能 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Expand', size: 10485760 //10mb },false); g_db2 = new DB({ //动态助手 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Activity', size: 1073741824 //1gb },false); g_db3 = new DB({ //数据分析 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Friend', size: 1073741824 //1gb },false); g_db4 = new DB({ //留言设置 driver: [localforage.WEBSQL, localforage.INDEXEDDB, localforage.LOCALSTORAGE], name: 'Steam assistant-Comment', size: 104857600 //100mb },false); await g_db.Write('g_conf',g_conf); //写入 await g_db.Write('g_uiConf',g_uiConf); //写入 //debugger //var data = await g_db.getAllKeyName(); //console.log("data",data); //var data = await g_db.getKeyNameByIndex(1); //console.log("data",data); //var data = await g_db.getLength(); //console.log("data",data); var data = await g_db.Read('g_conf'); //读取 console.log("data",data); var data = await g_db.Read('g_uiConf'); //读取 console.log("data",data); //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.Remove('g_conf'); //删除数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //await g_db.RemoveAll(); //删除所有数据 //var data = await g_db.ReadAll(); //读取所有数据 //console.log("data",data); //if(data.length == 0){ // console.log("没有数据!"); //} if(getLoginStatus() == false){ //判断是否登录,如果没有登录则不需要继续运行 layer.alert('请先登录Steam,才能继续使用哦~', {icon: 0},function(index){ if(g_conf[0].autoLogin == 1){ var obj = document.getElementsByClassName("global_action_link"); for (let i = 0; i < obj.length; i++) { if(obj[i].className == "global_action_link"){ obj[i].click(); //跳转到登录页面 } } } }); return false; } readConfInfo(g_steamID); //读取已保存的对应配置信息 if(type){ //第一次加载才需要监听这些事件 //1.监听url中的hash变化 //window.location.hash='state_online' => https://steamcommunity.com/id/miku-39/friends#state_online //页面不刷新,url改变,定位到指定锚点 window.addEventListener('hashchange',function(event){ console.log("1.监听url中的hash变化" + event); isReCreateUi(); //是否重新创建Ui }); //2.监听通过history来改变url的事件 //浏览器前进,后退等 window.addEventListener('popstate', function(event) { console.log("2.监听通过history来改变url的事件" + event); isReCreateUi(); //是否重新创建Ui }); //3.监听pushState和replaceState行为 //pushState可以监听到本页替换超链接 var _wr = function(type) { var orig = history[type]; return function() { var rv = orig.apply(this, arguments); var e = new Event(type); e.arguments = arguments; window.dispatchEvent(e); return rv; }; }; history.pushState = _wr('pushState'); history.replaceState = _wr('replaceState'); window.addEventListener('replaceState', function(e) { console.log('监听到replaceState!'); isReCreateUi(); //是否重新创建Ui }); window.addEventListener('pushState', function(e) { console.log('监听到pushState!'); var url = window.location.origin + window.location.pathname; //window.location.href //去除参数和锚点后的url //https://steamcommunity.com/id/miku-39/friends?l=english#state_online => https://steamcommunity.com/id/miku-39/friends isReCreateUi(); //是否重新创建Ui }); } } async createUI() { super.createUI(); //正常html代码 jQuery("#manage_friends").after(groupUI_html); if(g_uiConf.isShowQuickNavigationBar){ //是否显示快速导航栏 //快捷导航栏 jQuery(".responsive_page_template_content").after(ExpandUI_QuickNavigationBar_html); } UI.prototype.uiHandler(); //UI与UI事件等相关的处理程序 } async reCreateUI(){ if(await gc_menu_groups_invite_ui.initUI(false) != false){ await gc_menu_groups_invite_ui.createUI(); } } async private_saveUIConfFile() { } async private_readUIConfFile() { } } /** * uiHandler.js */ var commentTextarea_box; /*所有输入框*/ UI.prototype.uiHandler = async function(){ //UI与UI事件等相关的处理程序 //2.构建UI layui.use(['laydate', 'laypage', 'layer', 'table', 'carousel', 'upload', 'element', 'slider', 'colorpicker', 'form'], function() { var $ = layui.$; var laydate = layui.laydate //日期 ,laypage = layui.laypage //分页 ,layer = layui.layer //弹层 ,table = layui.table //表格 ,carousel = layui.carousel //轮播 ,upload = layui.upload //上传 ,element = layui.element //元素操作 ,slider = layui.slider //滑块 ,colorpicker = layui.colorpicker ,form = layui.form; //console.log(layui.layer); //向世界问个好 //layer.msg('Hello World'); //layer.alert('见到你真的很高兴', {icon: 6}); //layui.layer.alert("text"); //--------------------------------------------------------------------------------------------------------------------------------------------------------------------- // 好友数据统计 图表配置 table.render({ elem: '#friendStatistics' //,url:'/demo/table/user/' ,cellMinWidth: 80 ,cols: [[ {type:'numbers'} ,{type: 'checkbox'} ,{field:'Id', title:'ID', width:100, unresize: true, sort: true} ,{field:'Name', title:'名称', templet: '#usernameTpl'} ,{field:'Remark', title:'备注'} ,{field:'City', title: '国籍(城市)', minWidth:120, sort: true} ,{field:'Lever', title: '等级', minWidth:120, sort: true} ,{field:'Friends', title: '好友数量', minWidth:120, sort: true} ,{field:'Games', title: '游戏数量', minWidth:120, sort: true} ,{field:'DLCs', title: 'dlc数量', minWidth:120, sort: true} ,{field:'Workshops', title: '创意工坊数量', minWidth:120, sort: true} ,{field:'Artworks', title: '艺术作品数量', minWidth:120, sort: true} ,{field:'Activitys', title: '动态数量', minWidth:120, sort: true} ,{field:'front', title:'置顶', width:85, templet: '#switchTpl', unresize: true} ,{field:'lock', title:'是否锁定', width:110, templet: '#checkboxTpl', unresize: true} ]] ,data: [] ,page: true }); //加载数据 table.reload('friendStatistics', { elem: '#friendStatistics' ,page: true ,data: [ {Id: "1" ,Name: "xxx" ,Remark: "xx" ,City: "xx" ,Lever: "1" ,Friends: "1" ,Games: "1" ,DLCs: '1' ,Workshops: '1' ,Artworks: '1' ,Activitys: '1' }, {Id: "1" ,Name: "xxx" ,Remark: "xx" ,City: "xx" ,Lever: "1" ,Friends: "1" ,Games: "1" ,DLCs: '1' ,Workshops: '1' ,Artworks: '1' ,Activitys: '1' }, {Id: "1" ,Name: "xxx" ,Remark: "xx" ,City: "xx" ,Lever: "1" ,Friends: "1" ,Games: "1" ,DLCs: '1' ,Workshops: '1' ,Artworks: '1' ,Activitys: '1' }, ] }); //监听置顶操作 form.on('switch(frontDemo)', function(obj){ layer.tips(this.value + ' ' + this.name + ':'+ obj.elem.checked, obj.othis); }); //监听锁定操作 form.on('checkbox(lockDemo)', function(obj){ layer.tips(this.value + ' ' + this.name + ':'+ obj.elem.checked, obj.othis); }); //表单取值 layui.$('#LAY-component-form-getval').on('click', async function(){ var data = form.val('example'); //var jsonStr = JSON.stringify(data); switch (data.modules){ case '1': await setSelectTextMode(1); break; case '2': await setSelectTextMode(2); break; case '3': await setSelectTextMode(3); break; case '4': await setSelectTextMode(4); break; case '5': await setSelectTextMode(5); break; case '6': await setSelectTextMode(6); break; case '7': await setSelectTextMode(7); break; case '8': await setSelectTextMode(8); break; default: break; } console.log(data.modules); _addIDtoHandleLostfocus(); //添加ID来处理丢失的焦点 }); //--------------------------------------------------------------------------------------------------------------------------------------------------------------------- // 留言数据统计 图表配置 // Highcharts.setOptions({ // global : { // useUTC : false // } // }); // // Create the chart // Highcharts.stockChart('container_commentStatistics', { // chart : { // events : { // load : function () { // // set up the updating of the chart each second // var series = this.series[0]; // setInterval(function () { // var x = (new Date()).getTime(), // current time // y = Math.round(Math.random() * 100); // series.addPoint([x, y], true, true); // }, 1000); // } // } // }, // rangeSelector: { // buttons: [{ // count: 1, // type: 'minute', // text: '1M' // }, { // count: 5, // type: 'minute', // text: '5M' // }, { // type: 'all', // text: 'All' // }], // inputEnabled: false, // selected: 0 // }, // title : { // text : 'Live random data' // }, // tooltip: { // split: false // }, // exporting: { // enabled: false // }, // series : [{ // name : '随机数据', // data : (function () { // // generate an array of random data // var data = [], time = (new Date()).getTime(), i; // for (i = -999; i <= 0; i += 1) { // data.push([ // time + i * 1000, // Math.round(Math.random() * 100) // ]); // } // return data; // }()) // }] // }); //--------------------------------------------------------------------------------------------------------------------------------------------------------------------- // // 关系网统计 图表配置 // // Add the nodes option through an event call. We want to start with the parent // // item and apply separate colors to each child element, then the same color to // // grandchildren. // Highcharts.addEvent( // Highcharts.seriesTypes.networkgraph, // 'afterSetOptions', // function (e) { // var colors = Highcharts.getOptions().colors, // i = 0, // nodes = {}; // e.options.data.forEach(function (link) { // if (link[0] === 'Proto Indo-European') { // nodes['Proto Indo-European'] = { // id: 'Proto Indo-European', // marker: { // radius: 20 // } // }; // nodes[link[1]] = { // id: link[1], // marker: { // radius: 10 // }, // color: colors[i++] // }; // } else if (nodes[link[0]] && nodes[link[0]].color) { // nodes[link[1]] = { // id: link[1], // color: nodes[link[0]].color // }; // } // }); // e.options.nodes = Object.keys(nodes).map(function (id) { // return nodes[id]; // }); // } // ); // Highcharts.chart('container_relationshipStatistics', { // chart: { // type: 'networkgraph', // height: '100%' // }, // title: { // text: 'The Indo-European Laungauge Tree' // }, // subtitle: { // text: 'A Force-Directed Network Graph in Highcharts' // }, // plotOptions: { // networkgraph: { // keys: ['from', 'to'], // layoutAlgorithm: { // enableSimulation: true // } // } // }, // series: [{ // dataLabels: { // enabled: true // }, // data: [ // ['Proto Indo-European', 'Balto-Slavic'], // ['Proto Indo-European', 'Germanic'], // ['Proto Indo-European', 'Celtic'], // ['Proto Indo-European', 'Italic'], // ['Proto Indo-European', 'Hellenic'], // ['Proto Indo-European', 'Anatolian'], // ['Proto Indo-European', 'Indo-Iranian'], // ['Proto Indo-European', 'Tocharian'], // ['Indo-Iranian', 'Dardic'], // ['Indo-Iranian', 'Indic'], // ['Indo-Iranian', 'Iranian'], // ['Iranian', 'Old Persian'], // ['Old Persian', 'Middle Persian'], // ['Indic', 'Sanskrit'], // ['Italic', 'Osco-Umbrian'], // ['Italic', 'Latino-Faliscan'], // ['Latino-Faliscan', 'Latin'], // ['Celtic', 'Brythonic'], // ['Celtic', 'Goidelic'], // ['Germanic', 'North Germanic'], // ['Germanic', 'West Germanic'], // ['Germanic', 'East Germanic'], // ['North Germanic', 'Old Norse'], // ['North Germanic', 'Old Swedish'], // ['North Germanic', 'Old Danish'], // ['West Germanic', 'Old English'], // ['West Germanic', 'Old Frisian'], // ['West Germanic', 'Old Dutch'], // ['West Germanic', 'Old Low German'], // ['West Germanic', 'Old High German'], // ['Old Norse', 'Old Icelandic'], // ['Old Norse', 'Old Norwegian'], // ['Old Norwegian', 'Middle Norwegian'], // ['Old Swedish', 'Middle Swedish'], // ['Old Danish', 'Middle Danish'], // ['Old English', 'Middle English'], // ['Old Dutch', 'Middle Dutch'], // ['Old Low German', 'Middle Low German'], // ['Old High German', 'Middle High German'], // ['Balto-Slavic', 'Baltic'], // ['Balto-Slavic', 'Slavic'], // ['Slavic', 'East Slavic'], // ['Slavic', 'West Slavic'], // ['Slavic', 'South Slavic'], // // Leaves: // ['Proto Indo-European', 'Phrygian'], // ['Proto Indo-European', 'Armenian'], // ['Proto Indo-European', 'Albanian'], // ['Proto Indo-European', 'Thracian'], // ['Tocharian', 'Tocharian A'], // ['Tocharian', 'Tocharian B'], // ['Anatolian', 'Hittite'], // ['Anatolian', 'Palaic'], // ['Anatolian', 'Luwic'], // ['Anatolian', 'Lydian'], // ['Iranian', 'Balochi'], // ['Iranian', 'Kurdish'], // ['Iranian', 'Pashto'], // ['Iranian', 'Sogdian'], // ['Old Persian', 'Pahlavi'], // ['Middle Persian', 'Persian'], // ['Hellenic', 'Greek'], // ['Dardic', 'Dard'], // ['Sanskrit', 'Sindhi'], // ['Sanskrit', 'Romani'], // ['Sanskrit', 'Urdu'], // ['Sanskrit', 'Hindi'], // ['Sanskrit', 'Bihari'], // ['Sanskrit', 'Assamese'], // ['Sanskrit', 'Bengali'], // ['Sanskrit', 'Marathi'], // ['Sanskrit', 'Gujarati'], // ['Sanskrit', 'Punjabi'], // ['Sanskrit', 'Sinhalese'], // ['Osco-Umbrian', 'Umbrian'], // ['Osco-Umbrian', 'Oscan'], // ['Latino-Faliscan', 'Faliscan'], // ['Latin', 'Portugese'], // ['Latin', 'Spanish'], // ['Latin', 'French'], // ['Latin', 'Romanian'], // ['Latin', 'Italian'], // ['Latin', 'Catalan'], // ['Latin', 'Franco-Provençal'], // ['Latin', 'Rhaeto-Romance'], // ['Brythonic', 'Welsh'], // ['Brythonic', 'Breton'], // ['Brythonic', 'Cornish'], // ['Brythonic', 'Cuymbric'], // ['Goidelic', 'Modern Irish'], // ['Goidelic', 'Scottish Gaelic'], // ['Goidelic', 'Manx'], // ['East Germanic', 'Gothic'], // ['Middle Low German', 'Low German'], // ['Middle High German', '(High) German'], // ['Middle High German', 'Yiddish'], // ['Middle English', 'English'], // ['Middle Dutch', 'Hollandic'], // ['Middle Dutch', 'Flemish'], // ['Middle Dutch', 'Dutch'], // ['Middle Dutch', 'Limburgish'], // ['Middle Dutch', 'Brabantian'], // ['Middle Dutch', 'Rhinelandic'], // ['Old Frisian', 'Frisian'], // ['Middle Danish', 'Danish'], // ['Middle Swedish', 'Swedish'], // ['Middle Norwegian', 'Norwegian'], // ['Old Norse', 'Faroese'], // ['Old Icelandic', 'Icelandic'], // ['Baltic', 'Old Prussian'], // ['Baltic', 'Lithuanian'], // ['Baltic', 'Latvian'], // ['West Slavic', 'Polish'], // ['West Slavic', 'Slovak'], // ['West Slavic', 'Czech'], // ['West Slavic', 'Wendish'], // ['East Slavic', 'Bulgarian'], // ['East Slavic', 'Old Church Slavonic'], // ['East Slavic', 'Macedonian'], // ['East Slavic', 'Serbo-Croatian'], // ['East Slavic', 'Slovene'], // ['South Slavic', 'Russian'], // ['South Slavic', 'Ukrainian'], // ['South Slavic', 'Belarusian'], // ['South Slavic', 'Rusyn'] // ] // }] // }); //--------------------------------------------------------------------------------------------------------------------------------------------------------------------- // 当前配置统计 图表配置 //--------------------------------------------------------------------------------------------------------------------------------------------------------------------- // 查看好友配置统计 图表配置 //--------------------------------------------------------------------------------------------------------------------------------------------------------------------- // 多选下拉框 _ySelects(jQuery); jQuery('.selectBox').ySelect({ placeholder: '请先选择要翻译为的语言', searchText: '搜索~发现新世界~', showSearch: true, numDisplayed: 4, overflowText: '已选中 {n}项', isCheck: false }); //单选框选中和取消选择 if(jQuery('.nameAddType')[0] != undefined){ //单选框选中和取消选中 https://segmentfault.com/q/1010000004945347 jQuery('.nameAddType').on('click', function() { var ischecked = jQuery(this).data('checked'); if (!ischecked && this.checked) { jQuery(this).data('checked', true); } else { jQuery(this).prop('checked', false); jQuery(this).data('checked', false); } console.log(jQuery(this).data('checked')) }).data('checked', jQuery('.nameAddType').get(0).checked); } //--------------------------------------------------------------------------------------------------------------------------------------------------------------------- //请选择日期 laydate.render({ elem: '#test-limit2' ,trigger: 'click' ,min: 0 ,max: 99999 ,done: function(value, date){ //layer.alert('你选择的日期是:' + value + '<br>获得的对象是' + JSON.stringify(date)); var endTime = new Date(date.year,date.month-1,date.date,date.hours,date.minutes,date.seconds,0).getTime(); //选择的时间 var startTime = Math.round(new Date()); //现在的时间 if(endTime <= startTime) { layer.alert("请选择至少一天的时间差!"); return false; } let time = endTime >= startTime ? endTime - startTime: startTime - endTime; //计算时间差 //计算出相差天数 var str = ""; let days = Math.floor(time / (24 * 3600 * 1000)) //计算出小时数 let leave1 = time % (24 * 3600 * 1000) //计算天数后剩余的毫秒数 let hours = Math.floor(leave1 / (3600 * 1000)) //计算相差分钟数 let leave2 = leave1 % (3600 * 1000) //计算小时数后剩余的毫秒数 let minutes = Math.floor(leave2 / (60 * 1000)) //计算相差秒数 let leave3 = leave2 % (60 * 1000) //计算分钟数后剩余的毫秒数 //let seconds=Math.round(leave3/1000) let seconds = leave3 / 1000 //if (days > 0) str += days + "天"; //if (hours > 0) str += hours + "小时"; //if (minutes > 0) str += minutes + "分钟"; //if (seconds > 0) str += seconds + "秒"; var timeleftStr = "过"+ str +"后再留言"; var dayStr = "等待"+ (days+1) + "天, "; //console.log(str); jQuery('#test-limit1')[0].value = dayStr + timeleftStr; } }); // //请选择时间 // laydate.render({ // elem: '#test14' // ,type: 'time' // ,format: 'H时m分s秒' // ,done: function(value, date){ // //layer.alert('你选择的日期是:' + value + '<br>获得的对象是' + JSON.stringify(date)); // var endTime = new Date(date.year,date.month-1,date.date,date.hours,date.minutes,date.seconds,0).getTime(); //选择的时间 // var startTime = Math.round(new Date()); //现在的时间 // if(endTime <= startTime) // { // layer.alert("请选择至少一天的时间差!"); // return false; // } // let time = endTime >= startTime ? endTime - startTime: startTime - endTime; //计算时间差 // //计算出相差天数 // var str = ""; // let days = Math.floor(time / (24 * 3600 * 1000)) // //计算出小时数 // let leave1 = time % (24 * 3600 * 1000) //计算天数后剩余的毫秒数 // let hours = Math.floor(leave1 / (3600 * 1000)) // //计算相差分钟数 // let leave2 = leave1 % (3600 * 1000) //计算小时数后剩余的毫秒数 // let minutes = Math.floor(leave2 / (60 * 1000)) // //计算相差秒数 // let leave3 = leave2 % (60 * 1000) //计算分钟数后剩余的毫秒数 // //let seconds=Math.round(leave3/1000) // let seconds = leave3 / 1000 // //if (days > 0) // str += days + "天"; // //if (hours > 0) // str += hours + "小时"; // //if (minutes > 0) // str += minutes + "分钟"; // //if (seconds > 0) // str += seconds + "秒"; // var timeleftStr = "过"+ str +"后再留言"; // var dayStr = "等待"+ (days+1) + "天, ";//"过1小时后再留言" // //console.log(str); // jQuery('#test15')[0].value = dayStr + timeleftStr; // } // }); table.render({ elem: '#test' // ,height: 315 //容器高度 // ,url:'memberStatus?search=1' ,cellMinWidth: 80 //全局定义常规单元格的最小宽度,layui 2.2.1 新增 ,data: [] // ,autoSort: false //取消自动排序 ,cols: [ [ // {field:'id', title: 'ID', align: 'center',sort: true} ,{field:'memberName', title: 'ID', align: 'center',sort: true, width: '8%'} //width 支持:数字、百分比和不填写。你还可以通过 minWidth 参数局部定义当前单元格的最小宽度,layui 2.2.1 新增 ,{field:'team', title: '名称', align: 'center', sort: true,width: '12%'} //单元格内容水平居中 ,{field:'deviceCode', title: '留言时间', align: 'center',width: '17%',sort: true} //width 支持:数字、百分比和不填写。你还可以通过 minWidth 参数局部定义当前单元格的最小宽度,layui 2.2.1 新增 // ,{field:'hp', title: '血量', align: 'center',sort: true} ,{field:'hp', title: '待留言好友', align: 'center',width: '18%',sort: true} ,{field:'hitedNumber', title: '留言内容', align: 'center',width: '15%',sort: true} ,{field:'hitNumber', title: '已执行次数', align: 'center',width: '10%',sort: true} ,{field:'rePlenishBullet', title: '备注', align: 'center',width: '10%',sort: true} ,{field:'reviveNum', title: '设置', align: 'center',width: '10%',sort: true}, ] ]//标题栏 //设置表头 ,done:function (res,currentCount) { element.render() } }); //监听单元格编辑 table.on('edit(test3)', function(obj){ var value = obj.value //得到修改后的值 ,data = obj.data //得到所在行所有键值 ,field = obj.field; //得到字段 layer.msg('[ID: '+ data.id +'] ' + field + ' 字段更改为:'+ value); }); table.reload('test', { elem: '#test' ,page: true ,data: [ {memberName: "1" ,team: "留言1" ,deviceCode: "2020-5-1" ,hp: "All" ,hitedNumber: "早安安" ,hitNumber: "0" ,rePlenishBullet: "无" ,reviveNum: '<button type="button" class="layui-btn" id="editFriendGroup" style="height: 28px;line-height: 28px;width: 100%;padding: 0px;">属性</button>' }, {memberName: "1" ,team: "留言1" ,deviceCode: "2020-5-1" ,hp: "All" ,hitedNumber: "早安安" ,hitNumber: "0" ,rePlenishBullet: "无" ,reviveNum: '<button type="button" class="layui-btn" id="editFriendGroup" style="height: 28px;line-height: 28px;width: 100%;padding: 0px;">属性</button>' }, {memberName: "1" ,team: "留言1" ,deviceCode: "2020-5-1" ,hp: "All" ,hitedNumber: "早安安" ,hitNumber: "0" ,rePlenishBullet: "无" ,reviveNum: '<button type="button" class="layui-btn" id="editFriendGroup" style="height: 28px;line-height: 28px;width: 100%;padding: 0px;">属性</button>' }, ] }); //开启全功能 colorpicker.render({ elem: '#test-all1' ,color: 'rgba(7, 155, 140, 1)' ,format: 'rgb' ,predefine: true ,alpha: true ,done: function(color){ $('#test-all-input').val(color); //向隐藏域赋值 layer.tips('给指定隐藏域设置了颜色值:'+ color, this.elem); color || this.change(color); //清空时执行 change } ,change: function(color){ //给当前页面头部和左侧设置主题色 $('.header-demo,.layui-side .layui-nav').css('background-color', color); } }); //开启全功能 colorpicker.render({ elem: '#test-all2' ,color: 'rgba(7, 155, 140, 1)' ,format: 'rgb' ,predefine: true ,alpha: true ,done: function(color){ $('#test-all-input').val(color); //向隐藏域赋值 layer.tips('给指定隐藏域设置了颜色值:'+ color, this.elem); color || this.change(color); //清空时执行 change } ,change: function(color){ //给当前页面头部和左侧设置主题色 $('.header-demo,.layui-side .layui-nav').css('background-color', color); } }); //开启全功能 colorpicker.render({ elem: '#test-all3' ,color: 'rgba(7, 155, 140, 1)' ,format: 'rgb' ,predefine: true ,alpha: true ,done: function(color){ $('#test-all-input').val(color); //向隐藏域赋值 layer.tips('给指定隐藏域设置了颜色值:'+ color, this.elem); color || this.change(color); //清空时执行 change } ,change: function(color){ //给当前页面头部和左侧设置主题色 $('.header-demo,.layui-side .layui-nav').css('background-color', color); } }); //开启全功能 colorpicker.render({ elem: '#test-all4' ,color: 'rgba(7, 155, 140, 1)' ,format: 'rgb' ,predefine: true ,alpha: true ,done: function(color){ $('#test-all-input').val(color); //向隐藏域赋值 layer.tips('给指定隐藏域设置了颜色值:'+ color, this.elem); color || this.change(color); //清空时执行 change } ,change: function(color){ //给当前页面头部和左侧设置主题色 $('.header-demo,.layui-side .layui-nav').css('background-color', color); } }); //开启全功能 colorpicker.render({ elem: '#test-all5' ,color: 'rgba(7, 155, 140, 1)' ,format: 'rgb' ,predefine: true ,alpha: true ,done: function(color){ $('#test-all-input').val(color); //向隐藏域赋值 layer.tips('给指定隐藏域设置了颜色值:'+ color, this.elem); color || this.change(color); //清空时执行 change } ,change: function(color){ //给当前页面头部和左侧设置主题色 $('.header-demo,.layui-side .layui-nav').css('background-color', color); } }); //监听折叠 element.on('collapse(test)', function(data){ layer.msg('展开状态:'+ data.show); }); //请选择日期 laydate.render({ elem: '#test-limit3' ,type: 'date' ,trigger: 'click' ,range: '~' ,min: -7 ,max: 0 ,value: '2020-4-12 ~ 2020-4-19' ,isInitValue: true }); //监听指定开关 form.on('switch(switchTest)', async function(data){ layer.msg('开关checked:'+ (this.checked ? 'true' : 'false'), { offset: '6px' }); layer.tips('温馨提示:请注意开关状态的文字可以随意定义,而不仅仅是ON|OFF', data.othis); if(this.checked == true) //打开了 { await gc_friAct.Run(); } else //关闭了 { gc_friAct.Stop(); } }); //但是,如果你的HTML是动态生成的,自动渲染就会失效 //因此你需要在相应的地方,执行下述方法来进行渲染 form.render(); element.render('collapse'); }); //------------------------------------------------------------------------------------------------------------------------------- if (opinion() == 0) { //判断页面是pc端还是移动端 dvWidthFix(); } ToggleManageFriends(); //展开管理好友列表按钮 add_commentthread_textarea_allSelect(); //添加留言框全选 var Obj = new CEmoticonPopup($J('#emoticonbtn'), $J('#comment_textarea')); //表情相关 //ShowAlertDialog( 'Community Ban & Delete Comments', 'You do not have permissions to view this or you are not logged in.' ); //ShowConfirmDialog('您点击了移除好友按钮', '是否要移除选择的好友?','移除好友'); CEmoticonPopup.prototype.GetEmoticonClickClosure = function(strEmoticonName) { //重写,以适配多留言框 var _this = this; var strTextToInsert = ':' + strEmoticonName + ':'; return function() { console.log("表情添加到 "+inBoxonblurID); let obj; switch (inBoxonblurID){ case 0: obj = document.getElementById("comment_textarea"); break; case 1: obj = document.getElementById("comment_textarea_en"); break; case 2: obj = document.getElementById("comment_textarea_jp"); break; case 3: obj = document.getElementById("comment_textarea_zhc"); break; case 4: obj = document.getElementById("comment_textarea_zh_sg"); break; case 5: obj = document.getElementById("comment_textarea_zh_hant"); break; case 6: obj = document.getElementById("comment_textarea_zh_hk"); break; case 7: obj = document.getElementById("comment_textarea_zh_mo"); break; case 8: obj = document.getElementById("comment_textarea_zh_tw"); break; default: break; } var elTextArea = obj; //设置为指定的留言框 if (elTextArea) { var nSelectionStart = elTextArea.selectionStart; elTextArea.value = elTextArea.value.substr(0, nSelectionStart) + strTextToInsert + elTextArea.value.substr(nSelectionStart); elTextArea.selectionStart = nSelectionStart + strTextToInsert.length; } obj.focus(); //获取焦点,如果不在视野里,会把镜头拉过去 _this.DismissPopup(); //关闭表情输入框 if (window.DismissEmoticonHover) window.setTimeout(DismissEmoticonHover, 1); }; }; CEmoticonPopup.prototype.BuildPopup = function(){ //重写,以彻底隐藏表情选择框的同时提前加载表情 this.m_$Popup = $J('<div/>', {'class': 'emoticon_popup_ctn' } ); this.m_$Popup[0].style.display = "none"; //提前隐藏 var $PopupInner = $J('<div/>', {'class': 'emoticon_popup' } ); this.m_$Popup.append( $PopupInner ); var $Content = $J('<div/>', {'class': 'emoticon_popup_content' } ); $PopupInner.append( $Content ); for( var i = 0; i < CEmoticonPopup.sm_rgEmoticons.length; i++ ) { var strEmoticonName = CEmoticonPopup.sm_rgEmoticons[i].replace( /:/g, '' ); var strEmoticonURL = 'https://steamcommunity-a.akamaihd.net/economy/emoticon/' + strEmoticonName; var $Emoticon = $J('<div/>', {'class': 'emoticon_option', 'data-emoticon': strEmoticonName } ); var $Img = $J('<img/>', {'src': strEmoticonURL, 'class': 'emoticon' } ); $Emoticon.append( $Img ); $Emoticon.click( this.GetEmoticonClickClosure( strEmoticonName ) ); $Content.append( $Emoticon ); } $J(document.body).append( this.m_$Popup ); PositionEmoticonHover( this.m_$Popup, this.m_$EmoticonButton ); Obj.DismissPopup(); //关闭表情输入框 }; setTimeout(async function() { Obj.LoadEmoticons(); CEmoticonPopup.sm_deferEmoticonsLoaded.done(function() { (async function () { if (!Obj.m_$Popup) Obj.BuildPopup(); //重写,以彻底隐藏表情选择框的同时提前加载表情 else PositionEmoticonHover(Obj.m_$Popup, Obj.m_$EmoticonButton); //await emojiFix(); console.log("emoticon loaded Done."); })(); }); }, 0); //提前加载表情 _addIDtoHandleLostfocus(); //添加ID来处理丢失的焦点 document.addEventListener("mousedown", function(e){ if(e.target.id.indexOf("steamTextStyle_1")==0 || e.target.id.indexOf("LAY-component-form-getval")==0 || e.target.id.indexOf("emoticonbtn")==0 || e.target.className.indexOf("emoticon")==0 || e.target.className.indexOf("commentthread_entry_quotebox")==0 || e.target.className.indexOf("fs-label")==0 || e.target.id.indexOf("translationText")==0 || e.target.id.indexOf("select_is")==0 || e.target.id.indexOf("addCustomName")==0 || e.target.className.indexOf("btn_grey_black btn_small_thin")==0 || e.target.id.indexOf("comment_submit")==0 ){ //debugger //if(e.target.id == "LAY-component-form-getval"){ e.stopPropagation(); e.stopImmediatePropagation(); e.preventDefault(); // document.getElementById("LAY-component-form-getval").click(); return false; //} } }, false); //点击指定区域,输入框不失去焦点 /*代码位于event.js translationText翻译按钮事件*/ /*代码位于uiHandler.js 获取输入框和注册的scroll事件*/ /*代码位于ui.js inBoxShrinkage()判断是否需要重新进行定位*/ commentTextarea_box = document.getElementsByClassName('commentthread_textarea'); /*获取所有输入框*/ inBoxShrinkage('comment_textarea',"init"); //解决滚动屏幕事件 Cannot set property 'visible' of undefined,传入"init"参数无实际意义,只为了创建arrComment,而不执行收缩功能,防止Cannot read property 'value' of null错误 var getAllOffsetTopByChildEle = (ele)=>{ var OffsetTopSum = 0; var ParentObj; var currentObj = ele; //debugger //while(currentObj != document){ //OffsetTopSum += currentObj.offsetTop; //currentObj = currentObj.parentNode; currentObj = currentObj.parentNode; OffsetTopSum += currentObj.offsetTop; currentObj = currentObj.parentNode; OffsetTopSum += currentObj.offsetTop; //console.log("offsetTop:",currentObj.offsetTop,"scrollTop:",currentObj.scrollTop,"clientTop:",currentObj.clientTop); //} return OffsetTopSum; }; document.addEventListener('scroll',function(){ /*注册事件: 当滚动时,对所有输入框对象可见性进行判断*/ var visibleBottom = window.scrollY + document.documentElement.clientHeight; /*可见区域底部高度 = 滚动条高度 + 可视窗口高度 (显示窗口的底部坐标)*/ var visibleTop = window.scrollY; /*可见区域顶部高度 = 页面的滚动条滚动的距离 (显示窗口的顶部坐标)*/ for (var i = 0; i < commentTextarea_box.length; i++) { /*遍历所有元素并进行判断 commentTextarea_box[i].offsetTop*/ //var centerY = getAllOffsetTopByChildEle(commentTextarea_box[i]) + (commentTextarea_box[i].offsetHeight / 2); /*dom元素的中心坐标 = dom元素到最顶端的高度 + 自身高度的一半*/ var centerY = getAllOffsetTopByChildEle(commentTextarea_box[i]) - 10; //top var centerX = getAllOffsetTopByChildEle(commentTextarea_box[i]) + commentTextarea_box[i].offsetHeight + 20; //bottom if(centerY > visibleTop& centerX < visibleBottom){ /*当dom元素的中心坐标的X及Y坐标均大于显示窗口的顶部,且小于显示窗口的底部坐标时,那么就可以判断该坐标在可见区域*/ arrComment[i].visible = true; /*区域可见*/ //console.log('第'+i+'个区域可见',centerY,visibleTop,visibleBottom); }else{ arrComment[i].visible = false; /*区域不可见*/ //console.log('第'+i+'个区域不可见',centerY,visibleTop,visibleBottom); } } //console.log(''); }); console.log("注册所有的事件..."); await registeredAllEvents(); //注册所有的事件 if(!addRemoveFriendRemind()){/*添加删除好友提醒*/ console.log("添加删除好友提醒失败了~!"); } } /** * event.js */ async function registeredAllEvents() //注册所有的事件 { autoSetPageRefreshAndCloseWarn(true); //自动判断状态并设置页面刷新和关闭警告 addFriendMultipleSelectionMode(); //添加好友多选模式 jQuery("#addCustomName").click(async function() { //在留言框添加自定义称呼标识符 var inString = document.getElementById("comment_textarea"); var nSelectionStart = inString.selectionStart;// inString.value = inString.value.substr(0,nSelectionStart) + g_conf[0].strRemarkPlaceholder + inString.value.substr(nSelectionStart); document.getElementById("select_isCustom_checkbox").checked = true; //自动选择 自定义称呼模式 }); //<留言时的时间戳-目标时间戳> jQuery("#setTimeInterval").click(async function() { //为选择的好友设置留言时间间隔 }); jQuery("#unsetTimeInterval").click(async function() { //为选择的好友取消设置留言时间间隔 }); jQuery("#translationText").click(async function() { //翻译 //获取选择的语言 var selectLanguage = jQuery("#selectBoxID").ySelectedTexts(","); var selectLanguageArr = selectLanguage.split(','); if (selectLanguageArr.length == 1 && selectLanguageArr[0] == "") return; console.log("selectLanguageArr", selectLanguageArr); //获取输入的内容 var inString = document.getElementById("comment_textarea").value; if (inString == "") return; console.log("inString", inString); //获取原始语言选项 var options = document.getElementById('origLanguageSelectBox'); //获取选中的项目 var optionsValue = options[options.selectedIndex].value; console.log("optionsValue", optionsValue); for (let i = selectLanguageArr.length -1; i >= 0 ; i--) { //for (let i = 0; i < selectLanguageArr.length; i++) { g_conf[0].YunStatus = true; //正在运行 var _id; var newStrText; switch (selectLanguageArr[i]) { case '中文简体': _id = "_zhc"; newStrText = await GoogleTranslateRequest(optionsValue, zhc, inString); console.log("翻译为中文简体:", newStrText); if (document.getElementById('comment_textarea_zhc') == null) { jQuery("#translationOptions").after( '\ <div class="commentthread_entry_quotebox">\ <span>' + '翻译为中文简体' + '</span>\ <textarea class="commentthread_textarea" id="comment_textarea' + _id + '" onfocus="inBoxonblurID=3;openThisAndCloseOtherAllinBoxShrinkage(\'comment_textarea_zhc\',false);" onClick="" onblur="inBoxonblurID=3;inBoxShrinkage(\'comment_textarea_zhc\',true);" placeholder="添加留言(中文简体)" style="overflow: hidden; height: 28px;"></textarea>\ </div>' ); } document.getElementById('comment_textarea_zhc').value = newStrText; break; case '英语': _id = "_en"; newStrText = await GoogleTranslateRequest(optionsValue, en, inString); console.log("翻译为英语:", newStrText); if (document.getElementById('comment_textarea_en') == null) { jQuery("#translationOptions").after( '\ <div class="commentthread_entry_quotebox">\ <span>' + '翻译为英语' + '</span>\ <textarea class="commentthread_textarea" id="comment_textarea' + _id + '" onfocus="inBoxonblurID=1;openThisAndCloseOtherAllinBoxShrinkage(\'comment_textarea_en\',false);" onClick="" onblur="inBoxonblurID=1;inBoxShrinkage(\'comment_textarea_en\',true);" placeholder="添加留言(英语)" style="overflow: hidden; height: 28px;"></textarea>\ </div>' ); } document.getElementById('comment_textarea_en').value = newStrText; break; case '日语': _id = "_jp"; newStrText = await GoogleTranslateRequest(optionsValue, jp, inString); console.log("翻译为日语:", newStrText); if (document.getElementById('comment_textarea_jp') == null) { jQuery("#translationOptions").after( '\ <div class="commentthread_entry_quotebox">\ <span>' + '翻译为日语' + '</span>\ <textarea class="commentthread_textarea" id="comment_textarea' + _id + '" onfocus="inBoxonblurID=2;openThisAndCloseOtherAllinBoxShrinkage(\'comment_textarea_jp\',false);" onClick="" onblur="inBoxonblurID=2;inBoxShrinkage(\'comment_textarea_jp\',true);" placeholder="添加留言(日语)" style="overflow: hidden; height: 28px;"></textarea>\ </div>' ); } document.getElementById('comment_textarea_jp').value = newStrText; break; case "马新简体[zh-sg]": _id = "_zh_sg"; newStrText = await CNTranslateRequest('zh-sg', inString); console.log("翻译为马新简体[zh-sg]:", newStrText); if (document.getElementById('comment_textarea_zh_sg') == null) { jQuery("#translationOptions").after( '\ <div class="commentthread_entry_quotebox">\ <span>' + '翻译为马新简体' + '</span>\ <textarea class="commentthread_textarea" id="comment_textarea' + _id + '" onfocus="inBoxonblurID=4;openThisAndCloseOtherAllinBoxShrinkage(\'comment_textarea_zh_sg\',false);" onClick="" onblur="inBoxonblurID=4;inBoxShrinkage(\'comment_textarea_zh_sg\',true);" placeholder="添加留言(马新简体)" style="overflow: hidden; height: 28px;"></textarea>\ </div>' ); } document.getElementById('comment_textarea_zh_sg').value = newStrText; break; case "繁體中文[zh-hant]": _id = "_zh_hant"; newStrText = await CNTranslateRequest('zh-hant', inString); console.log("翻译为繁體中文[zh-hant]:", newStrText); if (document.getElementById('comment_textarea_zh_hant') == null) { jQuery("#translationOptions").after( '\ <div class="commentthread_entry_quotebox">\ <span>' + '翻译为繁體中文' + '</span>\ <textarea class="commentthread_textarea" id="comment_textarea' + _id + '" onfocus="inBoxonblurID=5;openThisAndCloseOtherAllinBoxShrinkage(\'comment_textarea_zh_hant\',false);" onClick="" onblur="inBoxonblurID=5;inBoxShrinkage(\'comment_textarea_zh_hant\',true);" placeholder="添加留言(繁體中文)" style="overflow: hidden; height: 28px;"></textarea>\ </div>' ); } document.getElementById('comment_textarea_zh_hant').value = newStrText; break; case "繁體中文(香港)[zh-hk]": _id = "_zh_hk"; newStrText = await CNTranslateRequest('zh-hk', inString); console.log("翻译为繁體中文(香港)[zh-hk]:", newStrText); if (document.getElementById('comment_textarea_zh_hk') == null) { jQuery("#translationOptions").after( '\ <div class="commentthread_entry_quotebox">\ <span>' + '翻译为繁體中文(香港)' + '</span>\ <textarea class="commentthread_textarea" id="comment_textarea' + _id + '" onfocus="inBoxonblurID=6;openThisAndCloseOtherAllinBoxShrinkage(\'comment_textarea_zh_hk\',false);" onClick="" onblur="inBoxonblurID=6;inBoxShrinkage(\'comment_textarea_zh_hk\',true);" placeholder="添加留言(繁體中文(香港))" style="overflow: hidden; height: 28px;"></textarea>\ </div>' ); } document.getElementById('comment_textarea_zh_hk').value = newStrText; break; case "繁體中文(澳门)[zh-mo]": _id = "_zh_mo"; newStrText = await CNTranslateRequest('zh-mo', inString); console.log("翻译为繁體中文(香港)[zh-hk]:", newStrText); if (document.getElementById('comment_textarea_zh_mo') == null) { jQuery("#translationOptions").after( '\ <div class="commentthread_entry_quotebox">\ <span>' + '翻译为繁體中文(澳门)' + '</span>\ <textarea class="commentthread_textarea" id="comment_textarea' + _id + '" onfocus="inBoxonblurID=7;openThisAndCloseOtherAllinBoxShrinkage(\'comment_textarea_zh_mo\',false);" onClick="" onblur="inBoxonblurID=7;inBoxShrinkage(\'comment_textarea_zh_mo\',true);" placeholder="添加留言(繁體中文(澳门))" style="overflow: hidden; height: 28px;"></textarea>\ </div>' ); } document.getElementById('comment_textarea_zh_mo').value = newStrText; break; case "繁體中文(台湾)[zh-tw]": _id = "_zh_tw"; newStrText = await CNTranslateRequest('zh-tw', inString); console.log("翻译为繁體中文(台湾)[zh-tw]:", newStrText); if (document.getElementById('comment_textarea_zh_tw') == null) { jQuery("#translationOptions").after( '\ <div class="commentthread_entry_quotebox">\ <span>' + '翻译为繁體中文(台湾)' + '</span>\ <textarea class="commentthread_textarea" id="comment_textarea' + _id + '" onfocus="inBoxonblurID=8;openThisAndCloseOtherAllinBoxShrinkage(\'comment_textarea_zh_tw\',false);" onClick="" onblur="inBoxonblurID=8;inBoxShrinkage(\'comment_textarea_zh_tw\',true);" placeholder="添加留言(繁體中文(台湾))" style="overflow: hidden; height: 28px;"></textarea>\ </div>' ); } document.getElementById('comment_textarea_zh_tw').value = newStrText; break; default: g_conf[0].YunStatus = false; //没有运行 break; } g_conf[0].isTranslationText = true; //进行了翻译 g_conf[0].YunStatus = false; //没有运行 } commentTextarea_box = document.getElementsByClassName('commentthread_textarea'); /*获取所有输入框*/ var change1; var autoTextarea = function(elem, extra, maxHeight) { extra = extra || 0; var isFirefox = !!document.getBoxObjectFor || 'mozInnerScreenX' in window, isOpera = !!window.opera && !!window.opera.toString().indexOf('Opera'), addEvent = function(type, callback) { elem.addEventListener ? elem.addEventListener(type, callback, false) : elem.attachEvent('on' + type, callback); }, getStyle = elem.currentStyle ? function(name) { var val = elem.currentStyle[name]; if (name === 'height' && val.search(/px/i) !== 1) { var rect = elem.getBoundingClientRect(); return rect.bottom - rect.top - parseFloat(getStyle('paddingTop')) - parseFloat(getStyle('paddingBottom')) + 'px'; }; return val; } : function(name) { return getComputedStyle(elem, null)[name]; }, minHeight = parseFloat(getStyle('height')); elem.style.resize = 'none'; change1 = function(e,id) { var scrollTop, height, padding = 0, style = elem.style; var obj = document.getElementById('strInBytes'); var commentText; if(id == undefined || id == null) commentText = document.getElementById(window.event.target.id); else commentText = document.getElementById(id); var numText = wordCount(commentText.value); obj.innerHTML = "当前字符字节数: <span id='strInBytes_Text'>" + numText + '</span>/999'; if (wordCount(commentText.value) >= 1000) { document.getElementById('strInBytes_Text').style.color = '#FF0000'; commentText.style.background = '#7b3863'; if(g_conf[0].isCommentRunStatus == false)/*如果正在留言则不清除(没有留言则清除)*/ jQuery('#log_head').html(''); jQuery('#log_head').html("<br><b style='color:#2CD8D6;'>字数超标啦! 请保持在1000字符以下. " + '当前字数:' + numText + '<b>'); g_conf[0].isWarnInfo = true; } else { document.getElementById('strInBytes_Text').style.color = '#32CD32'; commentText.style.background = '#1b2838'; if(g_conf[0].isCommentRunStatus == false && g_conf[0].isWarnInfo == true){ /*没有留言并且有警告信息才清除*/ jQuery('#log_head').html(''); g_conf[0].isWarnInfo = false; } } if (elem._length === elem.value.length) return; elem._length = elem.value.length; if (!isFirefox && !isOpera) { padding = parseInt(getStyle('paddingTop')) + parseInt(getStyle('paddingBottom')); }; scrollTop = document.body.scrollTop || document.documentElement.scrollTop; /*定位到最后*/ elem.style.height = minHeight + 'px'; if (elem.scrollHeight >= minHeight) { if (maxHeight && elem.scrollHeight > maxHeight) { height = maxHeight - padding; style.overflowY = 'auto'; } else { height = elem.scrollHeight - padding; style.overflowY = 'hidden'; }; style.height = height + extra + 'px'; var nHeight1 = height + extra; /*console.log('nHeight1',nHeight1,'newStr',newStr);*/ /*https://blog.csdn.net/weixin_34281477/article/details/93702604*/ /*https://www.cnblogs.com/cblogs/p/9293522.html*/ /*https://www.w3school.com.cn/tiy/t.asp?f=jseg_replace_1*/ var iIndex; for(let i=0;i<arrComment.length;i++) { if(id == undefined || id == null){ if(arrComment[i].id == window.event.target.id){ iIndex = i; break; } } else{ if(arrComment[i].id == id){ iIndex = i; break; } } } debugger; arrComment[iIndex].height = nHeight1;/*存储*/ scrollTop += parseInt(style.height) - elem.currHeight; if(!isNaN(scrollTop)){ document.body.scrollTop = scrollTop; document.documentElement.scrollTop = scrollTop; } elem.currHeight = parseInt(style.height); } }; }; inBoxShrinkage('comment_textarea_en',"init");//解决滚动屏幕事件 Cannot set property 'visible' of undefined,传入"init"参数无实际意义,只为了创建arrComment,而不执行收缩功能,防止Cannot read property 'value' of null错误 inBoxShrinkage('comment_textarea_jp',"init"); inBoxShrinkage('comment_textarea_zhc',"init"); inBoxShrinkage('comment_textarea_zh_sg',"init"); inBoxShrinkage('comment_textarea_zh_hant',"init"); inBoxShrinkage('comment_textarea_zh_hk',"init"); inBoxShrinkage('comment_textarea_zh_mo',"init"); inBoxShrinkage('comment_textarea_zh_tw',"init"); arrComment[1].height = 0; arrComment[1].scrollTop = 0; arrComment[2].height = 0; arrComment[2].scrollTop = 0; arrComment[3].height = 0; arrComment[3].scrollTop = 0; arrComment[4].height = 0; arrComment[4].scrollTop = 0; arrComment[5].height = 0; arrComment[5].scrollTop = 0; arrComment[6].height = 0; arrComment[6].scrollTop = 0; arrComment[7].height = 0; arrComment[7].scrollTop = 0; arrComment[8].height = 0; arrComment[8].scrollTop = 0; /*代码位于event.js translationText翻译按钮事件*/ /*代码位于uiHandler.js 获取输入框和注册的scroll事件*/ /*代码位于ui.js inBoxShrinkage()判断是否需要重新进行定位*/ }); jQuery("#setNoLeave").click(async function() { //为选择的好友设置不留言 var SpecialName = undefined; var steamName = undefined; var name = undefined; var mode = 0; const total = jQuery("#search_results .selected").length; //选择的朋友总数 if (total > 0) //选择的朋友总数 { if(g_conf[0].isNoCommentRunStatus == false) jQuery("#log_head1, #log_body1").html(""); var jqobj = jQuery("#search_results .selected"); for (let i = 0; i < jqobj.length; i++) { let cur = jqobj.get(i); let profileID = cur.getAttribute("data-steamid"); g_conf[0].YunStatus = true; //正在运行 g_conf[0].isNoCommentRunStatus = true; //-------------------------------------------------------------------- SpecialName = undefined; steamName = undefined; var nostrNoOperate = g_conf[0].strNoOperate + "-N"; // if (document.URL.indexOf("/friends") == -1) { //如果是在个人资料页面 // //获取备注 // var SpecialNameobj = document.getElementsByClassName("nickname"); //nickname // SpecialName = undefined; // if (SpecialNameobj != "undefined") { // SpecialName = SpecialNameobj[0].innerText; //备注 // } // //获取steam名称 // steamName = document.getElementsByClassName("actual_persona_name")[0].innerText; //steam名称 // name = steamName; // } else //否则如果是好友界面 //{ //获取名称,然后判断是备注还是steam名称 var SpecialNameobj = cur.getElementsByClassName("friend_block_content"); var nicknameObj = cur.getElementsByClassName("player_nickname_hint"); SpecialName = undefined; if (SpecialNameobj.length > 0) //安全检查 { if (nicknameObj.length > 0) //节点存在则是备注,不存在则是steam名称 { console.log("获取到的是备注"); SpecialName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("*")); //提取备注 steamName = undefined; //就没有名称 if (SpecialName.indexOf(g_conf[0].strNoOperate) != -1 || SpecialName.indexOf(nostrNoOperate) != -1) //检查是否设置了不留言标识 { jQuery("#log_body1")[0].innerHTML += "<a style='color:#00ffd8;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 已跳过, 没有设置备注! ' + profileID + ' ' + SpecialName + "</a><br>"; continue; } name = SpecialName; name = name + g_conf[0].strNoOperate; //组合 } else if (nicknameObj.length == 0) { console.log("获取到的是steam名称"); SpecialName = undefined; //就没有备注 steamName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("\n")); //提取steam名称 name = steamName; name = name + nostrNoOperate; //组合 } } //} console.log("[Debug] name:", name); (function(i, profileID) { var URL = "https://steamcommunity.com/profiles/" + profileID + "/ajaxsetnickname/"; jQuery.post(URL, { nickname: name, sessionid: g_sessionID }, function(response) { if (response.success === false) { jQuery("#log_body1")[0].innerHTML += "<a style='color:#ff2c85;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 设置备注失败了! ' + profileID + ' ' + name + ' ' + response.error + "</a><br>"; } else { jQuery("#log_body1")[0].innerHTML += '[' + (i + 1) + '/' + total + '] ' + "成功设置备注于 <a target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a>" + "<a style='color:#FB7299;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + "</a><br>"; } }).fail(function() { jQuery("#log_body1")[0].innerHTML += '<span style="color:#DA2626;">[' + (i + 1) + '/' + total + '] ' + "无法设置备注于 <a style='color:#DA2626;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a></span><br>"; }).always(function() { jQuery("#log_head1").html("<br><b>当前处理了 " + (i + 1) + "个, 总计 " + total + " 个好友.<b>"); }); })(i, profileID); await sleep(100); //console.log(cur) } g_conf[0].YunStatus = false; //没有运行 g_conf[0].isNoCommentRunStatus = false; window.location.reload(true); //强制从服务器重新加载当前页面 } }); jQuery("#unsetNoLeave").click(async function() { //为选择的好友取消设置不留言 var SpecialName = undefined; var steamName = undefined; var name = undefined; var mode = 0; const total = jQuery("#search_results .selected.selectable").length; //选择的朋友总数 if (total > 0) //选择的朋友总数 { if(g_conf[0].isNoCommentRunStatus == false) jQuery("#log_head1, #log_body1").html(""); var jqobj = jQuery("#search_results .selected.selectable"); for (let i = 0; i < jqobj.length; i++) { let cur = jqobj.get(i); let profileID = cur.getAttribute("data-steamid"); g_conf[0].YunStatus = true; //正在运行 g_conf[0].isNoCommentRunStatus = true; //-------------------------------------------------------------------- SpecialName = undefined; steamName = undefined; var nostrNoOperate = g_conf[0].strNoOperate + "-N"; // if (document.URL.indexOf("/friends") == -1) { //如果是在个人资料页面 // //获取备注 // var SpecialNameobj = document.getElementsByClassName("nickname"); //nickname // SpecialName = undefined; // if (SpecialNameobj != "undefined") { // SpecialName = SpecialNameobj[0].innerText; //备注 // } // //获取steam名称 // steamName = document.getElementsByClassName("actual_persona_name")[0].innerText; //steam名称 // name = steamName; // } else //否则如果是好友界面 //{ //获取名称,然后判断是备注还是steam名称 var SpecialNameobj = cur.getElementsByClassName("friend_block_content"); var nicknameObj = cur.getElementsByClassName("player_nickname_hint"); SpecialName = undefined; if (SpecialNameobj.length > 0) //安全检查 { if (nicknameObj.length > 0) //节点存在则是备注,不存在则是steam名称 { console.log("获取到的是备注"); SpecialName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("*")); //提取备注 steamName = undefined; //就没有名称 if (SpecialName.lastIndexOf(nostrNoOperate) != -1) //检查是否设置了国籍标识 { SpecialName = SpecialName.slice(0,SpecialName.lastIndexOf(nostrNoOperate)); //去掉国籍标识 name = ""; //去掉备注 } else if (SpecialName.lastIndexOf(g_conf[0].strNoOperate) != -1) //检查是否设置了国籍标识 { SpecialName = SpecialName.slice(0,SpecialName.lastIndexOf(g_conf[0].strNoOperate)); //去掉国籍标识 name = SpecialName; //使用原来的备注 }else { jQuery("#log_body1")[0].innerHTML += "<a style='color:#00ffd8;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 已跳过, 没有设置国籍不能取消! ' + profileID + ' ' + SpecialName + "</a><br>"; continue; } } else if (nicknameObj.length == 0) { console.log("获取到的是steam名称"); steamName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("\n")); //提取steam名称 jQuery("#log_body1")[0].innerHTML += "<a style='color:#00ffd8;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 已跳过, 没有备注不能取消! ' + profileID + ' ' + steamName + "</a><br>"; continue; } } //} console.log("[Debug] name:", name); (function(i, profileID) { var URL = "https://steamcommunity.com/profiles/" + profileID + "/ajaxsetnickname/"; jQuery.post(URL, { nickname: name, sessionid: g_sessionID }, function(response) { if (response.success === false) { jQuery("#log_body1")[0].innerHTML += "<a style='color:#ff2c85;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 设置备注失败了! ' + profileID + ' ' + name + ' ' + response.error + "</a><br>"; } else { jQuery("#log_body1")[0].innerHTML += '[' + (i + 1) + '/' + total + '] ' + "成功设置备注于 <a target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a>" + "<a style='color:#FB7299;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + "</a><br>"; } }).fail(function() { jQuery("#log_body1")[0].innerHTML += '[' + (i + 1) + '/' + total + '] ' + "<span style='color:#DA2626;'>无法设置备注于 <a style='color:#DA2626;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a></span><br>"; }).always(function() { jQuery("#log_head1").html("<br><b>当前处理了 " + (i + 1) + "个, 总计 " + total + " 个好友.<b>"); }); })(i, profileID); await sleep(1000); //console.log(cur) } g_conf[0].YunStatus = false; //没有运行 g_conf[0].isNoCommentRunStatus = false; window.location.reload(true); //强制从服务器重新加载当前页面 } }); jQuery("#setNationality").click(async function() { //为选择的好友设置国籍标识 //获取指定的国籍标识 var options = document.getElementById('nationalitySelectBox'); //获取选中的项目 var optionsValue = options[options.selectedIndex].value; console.log("optionsValue", optionsValue); var strNationality = '{' + optionsValue + '}'; //组合国籍标识 var strSpecialNationality = '{' + optionsValue + '-N}'; //组合格外国籍标识 //遍历所有选择的好友, //对已经设置了备注的好友,添加国籍标识; var SpecialName = undefined; var steamName = undefined; var name = undefined; var mode = 0; const total = jQuery("#search_results .selected").length; //选择的朋友总数 if (total > 0) //选择的朋友总数 { if(g_conf[0].isNationalityRunStatus == false) jQuery("#log_head1, #log_body1").html(""); var jqobj = jQuery("#search_results .selected"); for (let i = 0; i < jqobj.length; i++) { let cur = jqobj.get(i); let profileID = cur.getAttribute("data-steamid"); g_conf[0].YunStatus = true; //正在运行 g_conf[0].isNationalityRunStatus = true; //-------------------------------------------------------------------- SpecialName = undefined; steamName = undefined; // if (document.URL.indexOf("/friends") == -1) { //如果是在个人资料页面 // //获取备注 // var SpecialNameobj = document.getElementsByClassName("nickname"); //nickname // SpecialName = undefined; // if (SpecialNameobj != "undefined") { // SpecialName = SpecialNameobj[0].innerText; //备注 // } // //获取steam名称 // steamName = document.getElementsByClassName("actual_persona_name")[0].innerText; //steam名称 // name = steamName; // } else //否则如果是好友界面 //{ //获取名称,然后判断是备注还是steam名称 var SpecialNameobj = cur.getElementsByClassName("friend_block_content"); var nicknameObj = cur.getElementsByClassName("player_nickname_hint"); SpecialName = undefined; if (SpecialNameobj.length > 0) //安全检查 { if (nicknameObj.length > 0) //节点存在则是备注,不存在则是steam名称 { console.log("获取到的是备注"); SpecialName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("*")); //提取备注 steamName = undefined; //就没有名称 if (SpecialName.indexOf('{CN}') != -1 || SpecialName.indexOf('{CN-N}') != -1 || SpecialName.indexOf('{EN}') != -1 || SpecialName.indexOf('{EN-N}') != -1 || SpecialName.indexOf('{JP}') != -1 || SpecialName.indexOf('{JP-N}') != -1 || SpecialName.indexOf('{CN-SG}') != -1 || SpecialName.indexOf('{CN-SG-N}') != -1 || SpecialName.indexOf('{CN-HANT}') != -1 || SpecialName.indexOf('{CN-HANT-N}') != -1 || SpecialName.indexOf('{CN-HK}') != -1 || SpecialName.indexOf('{CN-HK-N}') != -1 || SpecialName.indexOf('{CN-MO}') != -1 || SpecialName.indexOf('{CN-MO-N}') != -1 || SpecialName.indexOf('{CN-TW}') != -1 || SpecialName.indexOf('{CN-TW-N}') != -1 ) //检查是否设置了国籍标识 { if (SpecialName.indexOf('{' + optionsValue + '}') != -1 || SpecialName.indexOf('{' + optionsValue + '-N}') != -1) //是否与待设置的国籍标识相同 { jQuery("#log_body1")[0].innerHTML += "<a style='color:#00ffd8;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 已跳过, 没有设置备注! ' + profileID + ' ' + SpecialName + "</a><br>"; continue; } else //重新设置国籍标识 { if (SpecialName.indexOf('-N}') != -1) { mode = 1; } SpecialName = SpecialName.slice(SpecialName.indexOf('}') + 1); //去掉国籍标识 } } if (mode == 0) { name = strNationality + SpecialName; //组合成为新的名称 国籍标识 } else if (mode == 1) { name = strSpecialNationality + SpecialName; //组合成为新的名称 格外国籍标识 mode = 0; } } else if (nicknameObj.length == 0) { console.log("获取到的是steam名称"); SpecialName = undefined; //就没有备注 steamName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("\n")); //提取steam名称 name = strSpecialNationality + steamName; //组合成为新的名称 格外国籍标识 } } //} console.log("[Debug] name:", name); (function(i, profileID) { var URL = "https://steamcommunity.com/profiles/" + profileID + "/ajaxsetnickname/"; jQuery.post(URL, { nickname: name, sessionid: g_sessionID }, function(response) { if (response.success === false) { jQuery("#log_body1")[0].innerHTML += "<a style='color:#ff2c85;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 设置备注失败了! ' + profileID + ' ' + name + ' ' + response.error + "</a><br>"; } else { jQuery("#log_body1")[0].innerHTML += '[' + (i + 1) + '/' + total + '] ' + "成功设置备注于 <a target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a>" + "<a style='color:#FB7299;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + "</a><br>"; } }).fail(function() { jQuery("#log_body1")[0].innerHTML += '<span style="color:#DA2626;">[' + (i + 1) + '/' + total + '] ' + "无法设置备注于 <a style='color:#DA2626;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a></span><br>"; }).always(function() { jQuery("#log_head1").html("<br><b>当前处理了 " + (i + 1) + "个, 总计 " + total + " 个好友.<b>"); }); })(i, profileID); await sleep(100); //console.log(cur) } g_conf[0].YunStatus = false; //没有运行 g_conf[0].isNationalityRunStatus = false; window.location.reload(true); //强制从服务器重新加载当前页面 } }); jQuery("#unsetNationality").click(async function() { //为选择的好友取消国籍标识 //获取指定的国籍标识 var options = document.getElementById('nationalitySelectBox'); //获取选中的项目 var optionsValue = options[options.selectedIndex].value; console.log("optionsValue", optionsValue); var strNationality = '{' + optionsValue + '}'; //组合国籍标识 var strSpecialNationality = '{' + optionsValue + '-N}'; //组合格外国籍标识 //遍历所有选择的好友, //对已经设置了备注的好友,添加国籍标识; var SpecialName = undefined; var steamName = undefined; var name = undefined; var mode = 0; const total = jQuery("#search_results .selected.selectable").length; //选择的朋友总数 if (total > 0) //选择的朋友总数 { if(g_conf[0].isNationalityRunStatus == false) jQuery("#log_head1, #log_body1").html(""); var jqobj = jQuery("#search_results .selected.selectable"); for (let i = 0; i < jqobj.length; i++) { let cur = jqobj.get(i); let profileID = cur.getAttribute("data-steamid"); g_conf[0].YunStatus = true; //正在运行 g_conf[0].isNationalityRunStatus = true; //-------------------------------------------------------------------- SpecialName = undefined; steamName = undefined; // if (document.URL.indexOf("/friends") == -1) { //如果是在个人资料页面 // //获取备注 // var SpecialNameobj = document.getElementsByClassName("nickname"); //nickname // SpecialName = undefined; // if (SpecialNameobj != "undefined") { // SpecialName = SpecialNameobj[0].innerText; //备注 // } // //获取steam名称 // steamName = document.getElementsByClassName("actual_persona_name")[0].innerText; //steam名称 // name = steamName; // } else //否则如果是好友界面 //{ //获取名称,然后判断是备注还是steam名称 var SpecialNameobj = cur.getElementsByClassName("friend_block_content"); var nicknameObj = cur.getElementsByClassName("player_nickname_hint"); SpecialName = undefined; if (SpecialNameobj.length > 0) //安全检查 { if (nicknameObj.length > 0) //节点存在则是备注,不存在则是steam名称 { console.log("获取到的是备注"); SpecialName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("*")); //提取备注 steamName = undefined; //就没有名称 if (SpecialName.indexOf('{CN}') != -1 || SpecialName.indexOf('{EN}') != -1 || SpecialName.indexOf('{JP}') != -1 || SpecialName.indexOf('{CN-SG}') != -1 || SpecialName.indexOf('{CN-HANT}') != -1 || SpecialName.indexOf('{CN-HK}') != -1 || SpecialName.indexOf('{CN-MO}') != -1 || SpecialName.indexOf('{CN-TW}') != -1 ) //检查是否设置了国籍标识 { SpecialName = SpecialName.slice(SpecialName.indexOf('}') + 1); //去掉国籍标识 name = SpecialName; //使用原来的备注 } else if (SpecialName.indexOf('{CN-N}') != -1 || SpecialName.indexOf('{EN-N}') != -1 || SpecialName.indexOf('{JP-N}') != -1 || SpecialName.indexOf('{CN-SG-N}') != -1 || SpecialName.indexOf('{CN-HANT-N}') != -1 || SpecialName.indexOf('{CN-HK-N}') != -1 || SpecialName.indexOf('{CN-MO-N}') != -1 || SpecialName.indexOf('{CN-TW-N}') != -1 ) //检查是否设置了国籍标识 { SpecialName = SpecialName.slice(SpecialName.indexOf('}') + 1); //去掉国籍标识 name = ""; //去掉备注 } else { jQuery("#log_body1")[0].innerHTML += "<a style='color:#00ffd8;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 已跳过, 没有设置国籍不能取消! ' + profileID + ' ' + SpecialName + "</a><br>"; continue; } } else if (nicknameObj.length == 0) { console.log("获取到的是steam名称"); steamName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("\n")); //提取steam名称 jQuery("#log_body1")[0].innerHTML += "<a style='color:#00ffd8;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 已跳过, 没有备注不能取消! ' + profileID + ' ' + steamName + "</a><br>"; continue; } } //} console.log("[Debug] name:", name); (function(i, profileID) { var URL = "https://steamcommunity.com/profiles/" + profileID + "/ajaxsetnickname/"; jQuery.post(URL, { nickname: name, sessionid: g_sessionID }, function(response) { if (response.success === false) { jQuery("#log_body1")[0].innerHTML += "<a style='color:#ff2c85;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 设置备注失败了! ' + profileID + ' ' + name + ' ' + response.error + "</a><br>"; } else { jQuery("#log_body1")[0].innerHTML += '[' + (i + 1) + '/' + total + '] ' + "成功设置备注于 <a target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a>" + "<a style='color:#FB7299;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + "</a><br>"; } }).fail(function() { jQuery("#log_body1")[0].innerHTML += '[' + (i + 1) + '/' + total + '] ' + "<span style='color:#DA2626;'>无法设置备注于 <a style='color:#DA2626;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a></span><br>"; }).always(function() { jQuery("#log_head1").html("<br><b>当前处理了 " + (i + 1) + "个, 总计 " + total + " 个好友.<b>"); }); })(i, profileID); await sleep(1000); //console.log(cur) } g_conf[0].isNationalityRunStatus = false; g_conf[0].YunStatus = false; //没有运行 window.location.reload(true); //强制从服务器重新加载当前页面 } }); //--------------------------------------------------------------------------------------------------------------- await jQuery("#comment_submit").click(async function() { //发送评论给选择的好友 setTimeout(async ()=>{ date = new Date(); startTime = date.getTime(); const total = jQuery("#search_results .selected.selectable").length; //选择的朋友总数 const msg = jQuery("#comment_textarea").val(); //获取评论内容 var newMgs = ""; var mode = 0; var SpecialName = undefined; var steamName = undefined; var name = undefined; if (total > 0 && msg.length > 0) { if(g_conf[0].isCommentRunStatus == false) jQuery("#log_head, #log_body").html(""); //jQuery(".selected").each(async function(i) { var jqobj = jQuery("#search_results .selected.selectable"); for (let i = 0; i < jqobj.length; i++) { let cur = jqobj.get(i); g_conf[0].YunStatus = true; //正在运行 g_conf[0].isCommentRunStatus = true; //-------------------------------------------------------------------- SpecialName = undefined; steamName = undefined; // if (document.URL.indexOf("/friends") == -1) { //如果是在个人资料页面 // //获取备注 // var SpecialNameobj = document.getElementsByClassName("nickname"); //nickname // SpecialName = undefined; // if (SpecialNameobj != "undefined") { // SpecialName = SpecialNameobj[0].innerText; //备注 // } // //获取steam名称 // steamName = document.getElementsByClassName("actual_persona_name")[0].innerText; //steam名称 // name = steamName; // } else //否则如果是好友界面 //{ //获取名称,然后判断是备注还是steam名称 var SpecialNameobj = cur.getElementsByClassName("friend_block_content"); var nicknameObj = cur.getElementsByClassName("player_nickname_hint"); SpecialName = undefined; if (SpecialNameobj.length > 0) //安全检查 { if (nicknameObj.length > 0) //节点存在则是备注,不存在则是steam名称 { console.log("获取到的是备注"); SpecialName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("*")); //提取备注 steamName = undefined; //就没有名称 name = SpecialName; } else if (nicknameObj.length == 0) { console.log("获取到的是steam名称"); SpecialName = undefined; //就没有备注 steamName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("\n")); //提取steam名称 name = steamName; } } //} //-------------------------------------------------------------------- //判断选择的模式 if ($("select_islName_checkbox").checked == true) { mode = 1; } else if ($("select_isSpecialName_checkbox").checked == true) { mode = 2; } else if ($("select_isCustom_checkbox").checked == true) { mode = 3; } else //如果都没有选中,则直接发送消息 mode = 0; if (mode == 1) { //是否为好友添加称呼 (如果好友没有备注则使用steam名称) //判断是否有备注,没有则使用steam名称 if (SpecialName != undefined) { let strNationality = SpecialName.slice(0, SpecialName.indexOf('}') + 1); //提取国籍 SpecialName = SpecialName.slice(SpecialName.indexOf('}') + 1); //去掉国籍标识 console.log("为" + steamName + "添加称呼: " + SpecialName); newMgs = SpecialName + msg; } else { console.log("为" + steamName + "添加称呼: " + steamName); newMgs = steamName + msg; } } else if (mode == 2) { //是否为好友添加称呼 (请为好友设置备注为需要的称呼,否则不添加称呼) //判断是否有备注,没有则不操作 if (SpecialName != undefined) { let strNationality = SpecialName.slice(0, SpecialName.indexOf('}') + 1); //提取国籍 SpecialName = SpecialName.slice(SpecialName.indexOf('}') + 1); //去掉国籍标识 console.log("为" + steamName + "添加称呼: " + SpecialName); newMgs = SpecialName + msg; } else { newMgs = msg; } } else if (mode == 3) { //是否为好友添加称呼 (请为好友设置备注为需要的称呼,否则不添加称呼) //判断是否有备注,没有则不操作 if (SpecialName != undefined) { let strNationality = SpecialName.slice(0, SpecialName.indexOf('}') + 1); //提取国籍 SpecialName = SpecialName.slice(SpecialName.indexOf('}') + 1); //去掉国籍标识 console.log("为" + steamName + "添加称呼: " + SpecialName); let str = msg; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),SpecialName); //把占位符全部替换为备注 } else { let str = msg; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),steamName); //把占位符全部替换为steam名称 } } else if (mode == 0) { //直接发送内容 newMgs = msg; } console.log("[Debug] mode:", mode); console.log("[Debug] SpecialName:", SpecialName, "steamName:", steamName); console.log("[Debug] newMgs:", newMgs, "msg:", msg); //-------------------------------------------------------------------- let profileID = cur.getAttribute("data-steamid"); if (SpecialName != undefined) { if (SpecialName.indexOf(g_conf[0].strNoOperate) != -1) { jQuery("#log_body")[0].innerHTML += "<a style='color:#00ffd8;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 已跳过留言! ' + profileID + ' ' + name + "</a><br>"; continue; } } (function(i, profileID) { //setTimeout(function() { jQuery.post("//steamcommunity.com/comment/Profile/post/" + profileID + "/-1/", { comment: newMgs, count: 6, sessionid: g_sessionID }, function(response) { if (response.success === false) { jQuery("#log_body")[0].innerHTML += "<a style='color:#ff2c85;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 留言失败了! ' + profileID + ' ' + name + ' ' + response.error + "</a><br>"; } else { jQuery("#log_body")[0].innerHTML += '[' + (i + 1) + '/' + total + '] ' + "成功发表评论于 <a target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a>" + "<span> → </span><a style='color:#FB7299;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "#commentthread_Profile_"+ profileID +"_textarea" + "\">" + newMgs + "</a><br>"; } }).fail(function() { jQuery("#log_body")[0].innerHTML += '<span style="color:#DA2626;">[' + (i + 1) + '/' + total + '] ' + "无法发表评论于 <a style='color:#DA2626;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a></span><br>"; }).always(function() { jQuery("#log_head").html("<br><b>当前处理了 " + (i + 1) + "个, 总计 " + total + " 个好友.<b>"); }); //}, i * 6000); })(i, profileID); await sleep(g_conf[0].delay * 1000) //console.log(cur) } date = new Date(); endTime = date.getTime(); let time = endTime - startTime; //console.log("time",time,endTime,startTime); //-------------------------------------------------------------------------------- //计算出相差天数 var str = ""; let days = Math.floor(time / (24 * 3600 * 1000)) //计算出小时数 let leave1 = time % (24 * 3600 * 1000) //计算天数后剩余的毫秒数 let hours = Math.floor(leave1 / (3600 * 1000)) //计算相差分钟数 let leave2 = leave1 % (3600 * 1000) //计算小时数后剩余的毫秒数 let minutes = Math.floor(leave2 / (60 * 1000)) //计算相差秒数 let leave3 = leave2 % (60 * 1000) //计算分钟数后剩余的毫秒数 //let seconds=Math.round(leave3/1000) let seconds = leave3 / 1000 if (days > 0) str += days + "天"; if (hours > 0) str += hours + "小时"; if (minutes > 0) str += minutes + "分钟"; if (seconds > 0) str += seconds + "秒"; //-------------------------------------------------------------------------------- jQuery("#log_body")[0].innerHTML += "<b>留言完毕! 用时: <span style='color:#35ff8b;'>" + str + "</span></b><br>"; //}); g_conf[0].isCommentRunStatus = false; g_conf[0].YunStatus = false; //没有运行 } else { alert("请确保您输入了一条消息并选择了1个或更多好友。"); } },0); }); //--------------------------------------------------------------------------------------------------------------- await jQuery("#comment_submit_special").click(async function() { //根据国籍发送评论给选择的好友 setTimeout(async()=>{ date = new Date(); startTime = date.getTime(); if(g_conf[0].isTranslationText == false){ return; } const total = jQuery("#search_results .selected.selectable").length; //选择的朋友总数 const msg = jQuery("#comment_textarea").val(); //获取评论内容 const msg_CN = jQuery("#comment_textarea_zhc").val(); //获取评论内容 const msg_EN = jQuery("#comment_textarea_en").val(); //获取评论内容 const msg_JP = jQuery("#comment_textarea_jp").val(); //获取评论内容 const msg_CN_SG = jQuery("#comment_textarea_zh_sg").val(); //获取评论内容 const msg_CN_HANT = jQuery("#comment_textarea_zh_hant").val(); //获取评论内容 const msg_CN_HK = jQuery("#comment_textarea_zh_hk").val(); //获取评论内容 const msg_CN_MO = jQuery("#comment_textarea_zh_mo").val(); //获取评论内容 const msg_CN_TW = jQuery("#comment_textarea_zh_tw").val(); //获取评论内容 var newMgs = ""; var mode = 0; var SpecialName = undefined; var steamName = undefined; var name = undefined; if (total > 0 && msg.length > 0) { if(g_conf[0].isCommentRunStatus == false) jQuery("#log_head, #log_body").html(""); //jQuery(".selected").each(async function(i) { //var jqobj = jQuery(".selected"); //var jqobj = jQuery(".selected[data-steamid]"); //排除掉选择的其他的东西 var jqobj = jQuery("#search_results .selected.selectable"); //排除掉选择的其他的东西 for (let i = 0; i < jqobj.length; i++) { let cur = jqobj.get(i); g_conf[0].YunStatus = true; //正在运行 g_conf[0].isCommentRunStatus = true; //-------------------------------------------------------------------- SpecialName = undefined; steamName = undefined; // if (document.URL.indexOf("/friends") == -1) { //如果是在个人资料页面 // //获取备注 // var SpecialNameobj = document.getElementsByClassName("nickname"); //nickname // SpecialName = undefined; // if (SpecialNameobj != "undefined") { // SpecialName = SpecialNameobj[0].innerText; //备注 // } // //获取steam名称 // steamName = document.getElementsByClassName("actual_persona_name")[0].innerText; //steam名称 // name = steamName; // } else //否则如果是好友界面 //{ //获取名称,然后判断是备注还是steam名称 var SpecialNameobj = cur.getElementsByClassName("friend_block_content"); var nicknameObj = cur.getElementsByClassName("player_nickname_hint"); SpecialName = undefined; if (SpecialNameobj.length > 0) //安全检查 { if (nicknameObj.length > 0) //节点存在则是备注,不存在则是steam名称 { console.log("获取到的是备注"); SpecialName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("*")); //提取备注 steamName = undefined; //就没有名称 name = SpecialName; } else if (nicknameObj.length == 0) { console.log("获取到的是steam名称"); SpecialName = undefined; //就没有备注 steamName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("\n")); //提取steam名称 name = steamName; } } //} //-------------------------------------------------------------------- //判断选择的模式 if ($("select_islName_checkbox").checked == true) { mode = 1; } else if ($("select_isSpecialName_checkbox").checked == true) { mode = 2; } else if ($("select_isCustom_checkbox").checked == true) { mode = 3; } else //如果都没有选中,则直接发送消息 mode = 0; var getVA = function(steamName, SpecialName) { return steamName == undefined ? steamName : SpecialName; }; console.log("DBG 0", steamName, SpecialName, name); if (mode == 1) { //是否为好友添加称呼 (如果好友没有备注则使用steam名称) //判断是否有备注,没有则使用steam名称 if (SpecialName != undefined) { let strNationality = SpecialName.slice(0, SpecialName.indexOf('}') + 1); //提取国籍 SpecialName = SpecialName.slice(SpecialName.indexOf('}') + 1); //去掉国籍标识 if (strNationality == "{CN}" || strNationality == "{CN-N}") { newMgs = SpecialName + msg_CN; } else if (strNationality == "{EN}" || strNationality == "{EN-N}") { newMgs = SpecialName + msg_EN; } else if (strNationality == "{JP}" || strNationality == "{JP-N}") { newMgs = SpecialName + msg_JP; } else if (strNationality == "{CN-SG}" || strNationality == "{CN-SG-N}") { newMgs = SpecialName + msg_CN_SG; } else if (strNationality == "{CN-HANT}" || strNationality == "{CN-HANT-N}") { newMgs = SpecialName + msg_CN_HANT; } else if (strNationality == "{CN-HK}" || strNationality == "{CN-HK-N}") { newMgs = SpecialName + msg_CN_HK; } else if (strNationality == "{CN-MO}" || strNationality == "{CN-MO-N}") { newMgs = SpecialName + msg_CN_MO; } else if (strNationality == "{CN-TW}" || strNationality == "{CN-TW-N}") { newMgs = SpecialName + msg_CN_TW; } else //没有设置国籍则默认使用英文,日语,简体中文,原始语言 { if (msg_EN != undefined && msg_EN != "") newMgs = SpecialName + msg_EN; else if (msg_JP != undefined && msg_JP != "") newMgs = SpecialName + msg_JP; else if (msg_CN != undefined && msg_CN != "") newMgs = SpecialName + msg_CN; else newMgs = SpecialName + msg; } console.log("DBG 1", steamName, SpecialName, name, strNationality); console.log("为" + SpecialName + "添加称呼: " + SpecialName); //newMgs = SpecialName + msg; } else { let strNationality = steamName.slice(0, steamName.indexOf('}') + 1); //提取国籍 steamName = steamName.slice(steamName.indexOf('}') + 1); //去掉国籍标识 if (strNationality == "{CN}" || strNationality == "{CN-N}") { newMgs = steamName + msg_CN; } else if (strNationality == "{EN}" || strNationality == "{EN-N}") { newMgs = steamName + msg_EN; } else if (strNationality == "{JP}" || strNationality == "{JP-N}") { newMgs = steamName + msg_JP; } else if (strNationality == "{CN-SG}" || strNationality == "{CN-SG-N}") { newMgs = steamName + msg_CN_SG; } else if (strNationality == "{CN-HANT}" || strNationality == "{CN-HANT-N}") { newMgs = steamName + msg_CN_HANT; } else if (strNationality == "{CN-HK}" || strNationality == "{CN-HK-N}") { newMgs = steamName + msg_CN_HK; } else if (strNationality == "{CN-MO}" || strNationality == "{CN-MO-N}") { newMgs = steamName + msg_CN_MO; } else if (strNationality == "{CN-TW}" || strNationality == "{CN-TW-N}") { newMgs = steamName + msg_CN_TW; } else //没有设置国籍则默认使用英文,日语,简体中文,原始语言 { if (msg_EN != undefined && msg_EN != "") newMgs = steamName + msg_EN; else if (msg_JP != undefined && msg_JP != "") newMgs = steamName + msg_JP; else if (msg_CN != undefined && msg_CN != "") newMgs = steamName + msg_CN; else newMgs = steamName + msg; } console.log("DBG 2", steamName, SpecialName, name, strNationality); console.log("为" + steamName + "添加称呼: " + steamName); //newMgs = steamName + msg; } } else if (mode == 2) { //是否为好友添加称呼 (请为好友设置备注为需要的称呼,否则不添加称呼) //判断是否有备注,没有则不操作 if (SpecialName != undefined) { let strNationality = SpecialName.slice(0, SpecialName.indexOf('}') + 1); //提取国籍 SpecialName = SpecialName.slice(SpecialName.indexOf('}') + 1); //去掉国籍标识 if (strNationality == "{CN}" || strNationality == "{CN-N}") { newMgs = SpecialName + msg_CN; } else if (strNationality == "{EN}" || strNationality == "{EN-N}") { newMgs = SpecialName + msg_EN; } else if (strNationality == "{JP}" || strNationality == "{JP-N}") { newMgs = SpecialName + msg_JP; } else if (strNationality == "{CN-SG}" || strNationality == "{CN-SG-N}") { newMgs = SpecialName + msg_CN_SG; } else if (strNationality == "{CN-HANT}" || strNationality == "{CN-HANT-N}") { newMgs = SpecialName + msg_CN_HANT; } else if (strNationality == "{CN-HK}" || strNationality == "{CN-HK-N}") { newMgs = SpecialName + msg_CN_HK; } else if (strNationality == "{CN-MO}" || strNationality == "{CN-MO-N}") { newMgs = SpecialName + msg_CN_MO; } else if (strNationality == "{CN-TW}" || strNationality == "{CN-TW-N}") { newMgs = SpecialName + msg_CN_TW; } else //没有设置国籍则默认使用英文,日语,简体中文,原始语言 { if (msg_EN != undefined && msg_EN != "") newMgs = SpecialName + msg_EN; else if (msg_JP != undefined && msg_JP != "") newMgs = SpecialName + msg_JP; else if (msg_CN != undefined && msg_CN != "") newMgs = SpecialName + msg_CN; else newMgs = SpecialName + msg; } console.log("DBG 3", steamName, SpecialName, name, strNationality); console.log("为" + steamName + "添加称呼: " + SpecialName); //newMgs = SpecialName + msg; } else { let strNationality = steamName.slice(0, steamName.indexOf('}') + 1); //提取国籍 steamName = steamName.slice(steamName.indexOf('}') + 1); //去掉国籍标识 if (strNationality == "{CN}" || strNationality == "{CN-N}") { newMgs = msg_CN; } else if (strNationality == "{EN}" || strNationality == "{EN-N}") { newMgs = msg_EN; } else if (strNationality == "{JP}" || strNationality == "{JP-N}") { newMgs = msg_JP; } else if (strNationality == "{CN-SG}" || strNationality == "{CN-SG-N}") { newMgs = msg_CN_SG; } else if (strNationality == "{CN-HANT}" || strNationality == "{CN-HANT-N}") { newMgs = msg_CN_HANT; } else if (strNationality == "{CN-HK}" || strNationality == "{CN-HK-N}") { newMgs = msg_CN_HK; } else if (strNationality == "{CN-MO}" || strNationality == "{CN-MO-N}") { newMgs = msg_CN_MO; } else if (strNationality == "{CN-TW}" || strNationality == "{CN-TW-N}") { newMgs = msg_CN_TW; } else //没有设置国籍则默认使用英文,日语,简体中文,原始语言 { if (msg_EN != undefined && msg_EN != "") newMgs = msg_EN; else if (msg_JP != undefined && msg_JP != "") newMgs = msg_JP; else if (msg_CN != undefined && msg_CN != "") newMgs = msg_CN; else newMgs = msg; } console.log("DBG 4", steamName, SpecialName, name, strNationality); //newMgs = msg; } } else if (mode == 3) { //是否为好友添加称呼 (请为好友设置备注为需要的称呼,否则不添加称呼) //判断是否有备注,没有则不操作 if (SpecialName != undefined) { let strNationality = SpecialName.slice(0, SpecialName.indexOf('}') + 1); //提取国籍 SpecialName = SpecialName.slice(SpecialName.indexOf('}') + 1); //去掉国籍标识 if (strNationality == "{CN}" || strNationality == "{CN-N}") { if(msg_CN == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_CN; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),SpecialName); //把占位符全部替换为备注 } else if (strNationality == "{EN}" || strNationality == "{EN-N}") { if(msg_EN == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_EN; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),SpecialName); //把占位符全部替换为备注 } else if (strNationality == "{JP}" || strNationality == "{JP-N}") { if(msg_JP == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_JP; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),SpecialName); //把占位符全部替换为备注 } else if (strNationality == "{CN-SG}" || strNationality == "{CN-SG-N}") { if(msg_CN_SG == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_CN_SG; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),SpecialName); //把占位符全部替换为备注 } else if (strNationality == "{CN-HANT}" || strNationality == "{CN-HANT-N}") { if(msg_CN_HANT == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_CN_HANT; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),SpecialName); //把占位符全部替换为备注 } else if (strNationality == "{CN-HK}" || strNationality == "{CN-HK-N}") { if(msg_CN_HK == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_CN_HK; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),SpecialName); //把占位符全部替换为备注 } else if (strNationality == "{CN-MO}" || strNationality == "{CN-MO-N}") { if(msg_CN_MO == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_CN_MO; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),SpecialName); //把占位符全部替换为备注 } else if (strNationality == "{CN-TW}" || strNationality == "{CN-TW-N}") { if(msg_CN_TW == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_CN_TW; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),SpecialName); //把占位符全部替换为备注 } else //没有设置国籍则默认使用英文,日语,简体中文,原始语言 { if (msg_EN != undefined && msg_EN != ""){ let str = msg_EN; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),SpecialName); //把占位符全部替换为备注 } else if (msg_JP != undefined && msg_JP != ""){ let str = msg_JP; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),SpecialName); //把占位符全部替换为备注 } else if (msg_CN != undefined && msg_CN != ""){ let str = msg_CN; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),SpecialName); //把占位符全部替换为备注 } else{ let str = msg; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),SpecialName); //把占位符全部替换为备注 } } console.log("DBG 3", steamName, SpecialName, name, strNationality); console.log("为" + steamName + "添加称呼: " + SpecialName); //newMgs = SpecialName + msg; } else { let strNationality = steamName.slice(0, steamName.indexOf('}') + 1); //提取国籍 steamName = steamName.slice(steamName.indexOf('}') + 1); //去掉国籍标识 if (strNationality == "{CN}" || strNationality == "{CN-N}") { if(msg_CN == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_CN; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),steamName); //把占位符全部替换为steam名称 } else if (strNationality == "{EN}" || strNationality == "{EN-N}") { if(msg_EN == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_EN; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),steamName); //把占位符全部替换为steam名称 } else if (strNationality == "{JP}" || strNationality == "{JP-N}") { if(msg_JP == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_JP; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),steamName); //把占位符全部替换为steam名称 } else if (strNationality == "{CN-SG}" || strNationality == "{CN-SG-N}") { if(msg_CN_SG == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_CN_SG; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),steamName); //把占位符全部替换为steam名称 } else if (strNationality == "{CN-HANT}" || strNationality == "{CN-HANT-N}") { if(msg_CN_HANT == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_CN_HANT; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),steamName); //把占位符全部替换为steam名称 } else if (strNationality == "{CN-HK}" || strNationality == "{CN-HK-N}") { if(msg_CN_HK == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_CN_HK; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),steamName); //把占位符全部替换为steam名称 } else if (strNationality == "{CN-MO}" || strNationality == "{CN-MO-N}") { if(msg_CN_MO == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_CN_MO; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),steamName); //把占位符全部替换为steam名称 } else if (strNationality == "{CN-TW}" || strNationality == "{CN-TW-N}") { if(msg_CN_TW == undefined){ return alert("您为选择的好友设置的国籍没有对应翻译过的文本,建议在'选择需要翻译的文本'那里的右上角选择全选,现在将停止运行.\n" + "好友名称:"+SpecialName+"国籍:"+strNationality); } let str = msg_CN_TW; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),steamName); //把占位符全部替换为steam名称 } else //没有设置国籍则默认使用英文,日语,简体中文,原始语言 { if (msg_EN != undefined && msg_EN != ""){ let str = msg_EN; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),steamName); //把占位符全部替换为steam名称 } else if (msg_JP != undefined && msg_JP != ""){ let str = msg_JP; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),steamName); //把占位符全部替换为steam名称 } else if (msg_CN != undefined && msg_CN != ""){ let str = msg_CN; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),steamName); //把占位符全部替换为steam名称 } else{ let str = msg; newMgs = str.replace(new RegExp(g_conf[0].strRemarkPlaceholder, 'g'),steamName); //把占位符全部替换为steam名称 } } console.log("DBG 4", steamName, SpecialName, name, strNationality); //newMgs = msg; } } else if (mode == 0) { //直接发送内容 let strNationality = name.slice(0, name.indexOf('}') + 1); //提取国籍 name = name.slice(name.indexOf('}') + 1); //去掉国籍标识 if (strNationality == "{CN}" || strNationality == "{CN-N}") { newMgs = msg_CN; } else if (strNationality == "{EN}" || strNationality == "{EN-N}") { newMgs = msg_EN; } else if (strNationality == "{JP}" || strNationality == "{JP-N}") { newMgs = msg_JP; } else if (strNationality == "{CN-SG}" || strNationality == "{CN-SG-N}") { newMgs = msg_CN_SG; } else if (strNationality == "{CN-HANT}" || strNationality == "{CN-HANT-N}") { newMgs = msg_CN_HANT; } else if (strNationality == "{CN-HK}" || strNationality == "{CN-HK-N}") { newMgs = msg_CN_HK; } else if (strNationality == "{CN-MO}" || strNationality == "{CN-MO-N}") { newMgs = msg_CN_MO; } else if (strNationality == "{CN-TW}" || strNationality == "{CN-TW-N}") { newMgs = msg_CN_TW; } else //没有设置国籍则默认使用英文,日语,简体中文,原始语言 { if (msg_EN != undefined && msg_EN != "") newMgs = msg_EN; else if (msg_JP != undefined && msg_JP != "") newMgs = msg_JP; else if (msg_CN != undefined && msg_CN != "") newMgs = msg_CN; else newMgs = msg; } console.log("DBG 5", steamName, SpecialName, name, strNationality); //ewMgs = msg; } console.log("[Debug] mode:", mode); console.log("[Debug] SpecialName:", SpecialName, "steamName:", steamName); console.log("[Debug] newMgs:", newMgs, "msg:", msg); //-------------------------------------------------------------------- let profileID = cur.getAttribute("data-steamid"); if (SpecialName != undefined) { if (SpecialName.indexOf(g_conf[0].strNoOperate) != -1) { jQuery("#log_body")[0].innerHTML += "<a style='color:#00ffd8;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 已跳过留言! ' + profileID + ' ' + name + "</a><br>"; continue; } } (function(i, profileID) { //setTimeout(function() { jQuery.post("//steamcommunity.com/comment/Profile/post/" + profileID + "/-1/", { comment: newMgs, count: 6, sessionid: g_sessionID }, function(response) { if (response.success === false) { jQuery("#log_body")[0].innerHTML += "<a style='color:#ff2c85;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + '[' + (i + 1) + '/' + total + '] 留言失败了! ' + profileID + ' ' + name + ' ' + response.error + "</a><br>"; } else { jQuery("#log_body")[0].innerHTML += '[' + (i + 1) + '/' + total + '] ' + "成功发表评论于 <a target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a>" + "<span> → </span><a style='color:#FB7299;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "#commentthread_Profile_"+ profileID +"_textarea" + "\">" + newMgs + "</a><br>"; } }).fail(function() { jQuery("#log_body")[0].innerHTML += '[' + (i + 1) + '/' + total + '] ' + "<span style='color:#DA2626;'>无法发表评论于 <a style='color:#DA2626;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + "\">" + profileID + ' ' + name + "</a></span><br>"; }).always(function() { jQuery("#log_head").html("<br><b>当前处理了 " + (i + 1) + "个, 总计 " + total + " 个好友.<b>"); }); //}, i * 6000); })(i, profileID); await sleep(g_conf[0].delay * 1000) //console.log(cur) } date = new Date(); endTime = date.getTime(); let time = endTime - startTime; //console.log("time",time,endTime,startTime); //-------------------------------------------------------------------------------- //计算出相差天数 var str = ""; let days = Math.floor(time / (24 * 3600 * 1000)) //计算出小时数 let leave1 = time % (24 * 3600 * 1000) //计算天数后剩余的毫秒数 let hours = Math.floor(leave1 / (3600 * 1000)) //计算相差分钟数 let leave2 = leave1 % (3600 * 1000) //计算小时数后剩余的毫秒数 let minutes = Math.floor(leave2 / (60 * 1000)) //计算相差秒数 let leave3 = leave2 % (60 * 1000) //计算分钟数后剩余的毫秒数 //let seconds=Math.round(leave3/1000) let seconds = leave3 / 1000 if (days > 0) str += days + "天"; if (hours > 0) str += hours + "小时"; if (minutes > 0) str += minutes + "分钟"; if (seconds > 0) str += seconds + "秒"; //-------------------------------------------------------------------------------- jQuery("#log_body")[0].innerHTML += "<b>留言完毕! 用时: <span style='color:#35ff8b;'>" + str + "</span></b><br>"; //}); g_conf[0].isCommentRunStatus = false; g_conf[0].YunStatus = false; //没有运行 } else { alert("请确保您输入了一条消息并选择了1个或更多好友。"); } },0); }); var GroupMode = 0; //分组标志 0没有分组 1是国籍 2是离线时间 jQuery("#NationalityGroup").click(async function() { //按国籍进行高亮分组 //1.遍历所有好友,针对不同国籍进行上色 //2.对好友进行排序 var SpecialName = undefined; var steamName = undefined; var name = undefined; var mode = 0; const total = jQuery("#search_results .selectable").length; //选择的朋友总数 if (total > 0) //选择的朋友总数 { jQuery("#log_head, #log_body").html(""); var jqobj = jQuery("#search_results .selectable"); for (let i = 0; i < jqobj.length; i++) { let cur = jqobj.get(i); let profileID = cur.getAttribute("data-steamid"); g_conf[0].YunStatus = true; //正在运行 //-------------------------------------------------------------------- SpecialName = undefined; steamName = undefined; // if (document.URL.indexOf("/friends") == -1) { //如果是在个人资料页面 // //获取备注 // var SpecialNameobj = document.getElementsByClassName("nickname"); //nickname // SpecialName = undefined; // if (SpecialNameobj != "undefined") { // SpecialName = SpecialNameobj[0].innerText; //备注 // } // //获取steam名称 // steamName = document.getElementsByClassName("actual_persona_name")[0].innerText; //steam名称 // name = steamName; // } else //否则如果是好友界面 //{ //获取名称,然后判断是备注还是steam名称 var SpecialNameobj = cur.getElementsByClassName("friend_block_content"); var nicknameObj = cur.getElementsByClassName("player_nickname_hint"); SpecialName = undefined; if (SpecialNameobj.length > 0) //安全检查 { if (nicknameObj.length > 0) //节点存在则是备注,不存在则是steam名称 { console.log("获取到的是备注"); SpecialName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("*")); //提取备注 steamName = undefined; //就没有名称 if (SpecialName.indexOf('{CN}') != -1 || SpecialName.indexOf('{EN}') != -1 || SpecialName.indexOf('{JP}') != -1 || SpecialName.indexOf('{CN-SG}') != -1 || SpecialName.indexOf('{CN-HANT}') != -1 || SpecialName.indexOf('{CN-HK}') != -1 || SpecialName.indexOf('{CN-MO}') != -1 || SpecialName.indexOf('{CN-TW}') != -1 ) //检查是否设置了国籍标识 { if (SpecialName.indexOf('{CN}') != -1) { cur.style.background = "#66cc"; } else if (SpecialName.indexOf('{EN}') != -1) { cur.style.background = "#0C7FB2"; } else if (SpecialName.indexOf('{JP}') != -1) { cur.style.background = "#008080"; } else if (SpecialName.indexOf('{CN-SG}') != -1) { cur.style.background = "#808000"; } else if (SpecialName.indexOf('{CN-HANT}') != -1) { cur.style.background = "#ae7844"; } else if (SpecialName.indexOf('{CN-HK}') != -1) { cur.style.background = "#649115"; } else if (SpecialName.indexOf('{CN-MO}') != -1) { cur.style.background = "#0f965b"; } else if (SpecialName.indexOf('{CN-TW}') != -1) { cur.style.background = "#173eac"; } } else if (SpecialName.indexOf('{CN-N}') != -1 || SpecialName.indexOf('{EN-N}') != -1 || SpecialName.indexOf('{JP-N}') != -1 || SpecialName.indexOf('{CN-SG-N}') != -1 || SpecialName.indexOf('{CN-HANT-N}') != -1 || SpecialName.indexOf('{CN-HK-N}') != -1 || SpecialName.indexOf('{CN-MO-N}') != -1 || SpecialName.indexOf('{CN-TW-N}') != -1 ) //检查是否设置了国籍标识 { if (SpecialName.indexOf('{CN-N}') != -1) { cur.style.background = "#66cc"; cur.style.borderColor = "#FF00FF"; } else if (SpecialName.indexOf('{EN-N}') != -1) { cur.style.background = "#0C7FB2"; cur.style.borderColor = "#FF00FF"; } else if (SpecialName.indexOf('{JP-N}') != -1) { cur.style.background = "#008080"; cur.style.borderColor = "#FF00FF"; } else if (SpecialName.indexOf('{CN-SG-N}') != -1) { cur.style.background = "#808000"; cur.style.borderColor = "#FF00FF"; } else if (SpecialName.indexOf('{CN-HANT-N}') != -1) { cur.style.background = "#ae7844"; cur.style.borderColor = "#FF00FF"; } else if (SpecialName.indexOf('{CN-HK-N}') != -1) { cur.style.background = "#649115"; cur.style.borderColor = "#FF00FF"; } else if (SpecialName.indexOf('{CN-MO-N}') != -1) { cur.style.background = "#0f965b"; cur.style.borderColor = "#FF00FF"; } else if (SpecialName.indexOf('{CN-TW-N}') != -1) { cur.style.background = "#173eac"; cur.style.borderColor = "#FF00FF"; } } else { //设置了备注没有设置国籍 cur.style.background = "#188038"; } } else if (nicknameObj.length == 0) { console.log("获取到的是steam名称"); steamName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("\n")); //提取steam名称 //jQuery("#log_body")[0].innerHTML += // "<a style='color:#00ffd8;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + // "\">" + '[' + (i + 1) + '/' + total + '] 已跳过, 没有备注不能取消! ' + profileID + ' ' + steamName + "</a><br>"; //continue; } } //} console.log("[Debug] name:", SpecialName); //await sleep(1000); //console.log(cur) } g_conf[0].YunStatus = false; //没有运行 //window.location.reload(true); //强制从服务器重新加载当前页面 } }); await jQuery("#NationalitySortGroup").click(async function() { //按国籍进行排序分组 var SpecialName = undefined; var steamName = undefined; var name = undefined; var mode = 0; const total = jQuery("#search_results .selectable").length; //所有的朋友总数 jQuery("#log_head, #log_body").html(""); var jqobj = jQuery("#search_results .selectable"); //所有的朋友 var child_CN, child_EN, child_JP, child_CN_SG, child_CN_HANTd, child_CN_HK, child_CN_MO, child_CN_TW; if (GroupMode != 1) { var mainFriendObj; if (GroupMode == 2) { //节点已经被模式2处理过 //备份和处理 if (document.getElementById("search_results1") == null) { //没有被模式1处理过 mainFriendObj = document.getElementById("search_results0"); //获取原节点 var newCopyObj = mainFriendObj.cloneNode(true); var mainFriendObj1 = document.getElementById("search_results"); //获取之前模式的节点 mainFriendObj1.style.display = "none"; //之前模式的节点隐藏 mainFriendObj1.id = "search_results2"; //之前模式的节点 mainFriendObj1.className = "profile_friends search_results2"; //之前模式的节点 newCopyObj.style.display = ""; //克隆的原节点取消隐藏(显示) newCopyObj.id = "search_results"; //克隆的原节点 newCopyObj.className = "profile_friends search_results"; //克隆的原节点 mainFriendObj.parentNode.appendChild(newCopyObj); //再添加一个新的备份节点 } else { //被模式1处理过 var obj = document.getElementById("search_results1"); var mainFriendObj1 = document.getElementById("search_results"); //获取之前模式的节点 mainFriendObj = document.getElementById("search_results0"); //获取原节点 mainFriendObj1.style.display = "none"; //之前模式的节点隐藏 mainFriendObj1.id = "search_results2"; //之前模式的节点 mainFriendObj1.className = "profile_friends search_results2"; //之前模式的节点 obj.style.display = ""; //取消隐藏(显示) obj.id = "search_results"; //节点 obj.className = "profile_friends search_results"; //节点 } } else { //节点还没有被动过 //备份和处理 mainFriendObj = document.getElementById("search_results"); //获取原节点 var newCopyObj = mainFriendObj.cloneNode(true); newCopyObj.style.display = "none"; //克隆的原节点隐藏 newCopyObj.id = "search_results0"; //克隆的原节点 newCopyObj.className = "profile_friends search_results0"; //克隆的原节点 mainFriendObj.parentNode.appendChild(newCopyObj); //再添加一个新的备份节点 } // //备份和处理 // var mainFriendObj = document.getElementById("search_results"); //获取原节点 // var newCopyObj = mainFriendObj.cloneNode(true); // newCopyObj.style.display = "none"; //隐藏 // mainFriendObj.parentNode.appendChild(newCopyObj); //再添加一个新的备份节点 var StateObj = mainFriendObj.getElementsByClassName("state_block"); for (let i = 0; i < StateObj.length; i++) { StateObj[i].style.display = "none"; //隐藏状态条 } //创建新盒子和克隆分组节点 console.log("开始分组..."); child_CN = document.createElement('div'); //创建 child_CN.id = "Firend_CN"; child_CN.style.display = "flex"; child_CN.style.flex = "1 100%"; child_CN.style.flexFlow = "row wrap"; child_CN.style.margin = "8px 0px 0px 0px"; // child_CN.style.justifyContent = "space-start"; mainFriendObj.appendChild(child_CN); child_EN = child_CN.cloneNode(true); //克隆 child_EN.id = "Firend_EN"; mainFriendObj.appendChild(child_EN); child_JP = child_EN.cloneNode(true); //克隆 child_JP.id = "Firend_JP"; mainFriendObj.appendChild(child_JP); child_CN_SG = child_EN.cloneNode(true); //克隆 child_CN_SG.id = "Firend_CN_SG"; mainFriendObj.appendChild(child_CN_SG); child_CN_HANTd = child_EN.cloneNode(true); //克隆 child_CN_HANTd.id = "Firend_CN_HANTd"; mainFriendObj.appendChild(child_CN_HANTd); child_CN_HK = child_EN.cloneNode(true); //克隆 child_CN_HK.id = "Firend_CN_HK"; mainFriendObj.appendChild(child_CN_HK); child_CN_MO = child_EN.cloneNode(true); //克隆 child_CN_MO.id = "Firend_CN_MO"; mainFriendObj.appendChild(child_CN_MO); child_CN_TW = child_EN.cloneNode(true); //克隆 child_CN_TW.id = "Firend_CN_TW"; mainFriendObj.appendChild(child_CN_TW); //------------------------------------------------- var newGroupTitle = StateObj[0].cloneNode(true); //克隆 newGroupTitle.style.display = ""; //去除隐藏样式 newGroupTitle.innerText = "CN"; child_CN.appendChild(newGroupTitle); newGroupTitle = newGroupTitle.cloneNode(true); //克隆 newGroupTitle.innerText = "EN"; child_EN.appendChild(newGroupTitle); newGroupTitle = newGroupTitle.cloneNode(true); //克隆 newGroupTitle.innerText = "JP"; child_JP.appendChild(newGroupTitle); newGroupTitle = newGroupTitle.cloneNode(true); //克隆 newGroupTitle.innerText = "CN_SG"; child_CN_SG.appendChild(newGroupTitle); newGroupTitle = newGroupTitle.cloneNode(true); //克隆 newGroupTitle.innerText = "CN_HANTd"; child_CN_HANTd.appendChild(newGroupTitle); newGroupTitle = newGroupTitle.cloneNode(true); //克隆 newGroupTitle.innerText = "CN_HK"; child_CN_HK.appendChild(newGroupTitle); newGroupTitle = newGroupTitle.cloneNode(true); //克隆 newGroupTitle.innerText = "CN_MO"; child_CN_MO.appendChild(newGroupTitle); newGroupTitle = newGroupTitle.cloneNode(true); //克隆 newGroupTitle.innerText = "CN_TW"; child_CN_TW.appendChild(newGroupTitle); //遍历所有节点,向盒子里添加节点 for (let i = 0; i < jqobj.length; i++) { let cur = jqobj.get(i); let profileID = cur.getAttribute("data-steamid"); //-------------------------------------------------------------------- SpecialName = undefined; steamName = undefined; // if (document.URL.indexOf("/friends") == -1) { //如果是在个人资料页面 // //获取备注 // var SpecialNameobj = document.getElementsByClassName("nickname"); //nickname // SpecialName = undefined; // if (SpecialNameobj != "undefined") { // SpecialName = SpecialNameobj[0].innerText; //备注 // } // //获取steam名称 // steamName = document.getElementsByClassName("actual_persona_name")[0].innerText; //steam名称 // name = steamName; // } else //否则如果是好友界面 //{ //获取名称,然后判断是备注还是steam名称 var SpecialNameobj = cur.getElementsByClassName("friend_block_content"); var nicknameObj = cur.getElementsByClassName("player_nickname_hint"); SpecialName = undefined; if (SpecialNameobj.length > 0) //安全检查 { if (nicknameObj.length > 0) //节点存在则是备注,不存在则是steam名称 { //console.log("获取到的是备注"); SpecialName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("*")); //提取备注 steamName = undefined; //就没有名称 if (SpecialName.indexOf('{CN}') != -1 || SpecialName.indexOf('{CN-N}') != -1) { //检查是否设置了国籍标识 child_CN.appendChild(SpecialNameobj[0].parentNode); } else if (SpecialName.indexOf('{EN}') != -1 || SpecialName.indexOf('{EN-N}') != -1) { child_EN.appendChild(SpecialNameobj[0].parentNode); } else if (SpecialName.indexOf('{JP}') != -1 || SpecialName.indexOf('{JP-N}') != -1) { child_JP.appendChild(SpecialNameobj[0].parentNode); } else if (SpecialName.indexOf('{CN-SG}') != -1 || SpecialName.indexOf('{CN-SG-N}') != -1) { child_CN_SG.appendChild(SpecialNameobj[0].parentNode); } else if (SpecialName.indexOf('{CN-HANT}') != -1 || SpecialName.indexOf('{CN-HANT-N}') != -1) { child_CN_HANT.appendChild(SpecialNameobj[0].parentNode); } else if (SpecialName.indexOf('{CN-HK}') != -1 || SpecialName.indexOf('{CN-HK-N}') != -1) { child_CN_HK.appendChild(SpecialNameobj[0].parentNode); } else if (SpecialName.indexOf('{CN-MO}') != -1 || SpecialName.indexOf('{CN-MO-N}') != -1) { child_CN_MO.appendChild(SpecialNameobj[0].parentNode); } else if (SpecialName.indexOf('{CN-TW}') != -1 || SpecialName.indexOf('{CN-TW-N}') != -1) { child_CN_TW.appendChild(SpecialNameobj[0].parentNode); } else { // jQuery("#log_body")[0].innerHTML += // "<a style='color:#00ffd8;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + // "\">" + '[' + (i + 1) + '/' + total + '] 已跳过, 没有设置国籍不能取消! ' + profileID + ' ' + SpecialName + "</a><br>"; // continue; } } else if (nicknameObj.length == 0) { //console.log("获取到的是steam名称"); // steamName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("\n")); //提取steam名称 // jQuery("#log_body")[0].innerHTML += // "<a style='color:#00ffd8;' target='_blank' href=\"http://steamcommunity.com/profiles/" + profileID + // "\">" + '[' + (i + 1) + '/' + total + '] 已跳过, 没有备注不能取消! ' + profileID + ' ' + steamName + "</a><br>"; // continue; } } //} //console.log("[Debug] name:", name); } GroupMode = 1; } }); await jQuery("#OfflineTimeGroup").click(async function() { //按在线时间进行排序分组 var SpecialName = undefined; var steamName = undefined; var name = undefined; var mode = 0; const total = jQuery("#search_results .selectable.offline").length; //选择的朋友总数 if (total > 0) //选择的朋友总数 { jQuery("#log_head, #log_body").html(""); var jqobj = jQuery("#search_results .selectable.offline"); //选择离线的好友 var ArrOfflineTime = []; if (GroupMode != 2) { var mainFriendObj; if (GroupMode == 1) { //节点已经被模式1处理过 //备份和处理 if (document.getElementById("search_results2") == null) { //没有被模式2处理过 mainFriendObj = document.getElementById("search_results0"); //获取原节点 var newCopyObj = mainFriendObj.cloneNode(true); var mainFriendObj1 = document.getElementById("search_results"); //获取之前模式的节点 mainFriendObj1.style.display = "none"; //之前模式的节点隐藏 mainFriendObj1.id = "search_results1"; //之前模式的节点 mainFriendObj1.className = "profile_friends search_results1"; //之前模式的节点 newCopyObj.style.display = ""; //克隆的原节点取消隐藏(显示) newCopyObj.id = "search_results"; //克隆的原节点 newCopyObj.className = "profile_friends search_results"; //克隆的原节点 mainFriendObj.parentNode.appendChild(newCopyObj); //再添加一个新的备份节点 } else { //被模式2处理过 var obj = document.getElementById("search_results2"); var mainFriendObj1 = document.getElementById("search_results"); //获取之前模式的节点 mainFriendObj = document.getElementById("search_results0"); //获取原节点 mainFriendObj1.style.display = "none"; //之前模式的节点隐藏 mainFriendObj1.id = "search_results1"; //之前模式的节点 mainFriendObj1.className = "profile_friends search_results1"; //之前模式的节点 obj.style.display = ""; //取消隐藏(显示) obj.id = "search_results"; //节点 obj.className = "profile_friends search_results"; //节点 } } else { //节点还没有被动过 //备份和处理 mainFriendObj = document.getElementById("search_results"); //获取原节点 var newCopyObj = mainFriendObj.cloneNode(true); newCopyObj.style.display = "none"; //克隆的原节点隐藏 newCopyObj.id = "search_results0"; //克隆的原节点 newCopyObj.className = "profile_friends search_results0"; //克隆的原节点 mainFriendObj.parentNode.appendChild(newCopyObj); //再添加一个新的备份节点 } var StateObj = mainFriendObj.getElementsByClassName("state_block"); for (let i = 0; i < StateObj.length; i++) { StateObj[i].style.display = "none"; //隐藏状态条 } //创建新盒子和克隆分组节点 console.log("开始分组..."); child_Offline = document.createElement('div'); //创建 child_Offline.id = "Firend_Offline"; child_Offline.style.display = "flex"; child_Offline.style.flex = "1 100%"; child_Offline.style.flexFlow = "row wrap"; child_Offline.style.margin = "8px 0px 0px 0px"; // child_Offline.style.justifyContent = "space-start"; mainFriendObj.appendChild(child_Offline); child_Online = child_Offline.cloneNode(true); //克隆 child_Online.id = "Firend_Online"; mainFriendObj.appendChild(child_Online); child_InGame = child_Offline.cloneNode(true); //克隆 child_InGame.id = "Firend_InGame"; mainFriendObj.appendChild(child_InGame); //------------------------------------------------- var newGroupTitle = StateObj[0].cloneNode(true); //克隆 newGroupTitle.style.display = ""; //去除隐藏样式 newGroupTitle.innerText = "Offline"; child_Offline.appendChild(newGroupTitle); newGroupTitle = newGroupTitle.cloneNode(true); //克隆 newGroupTitle.innerText = "Online"; child_Online.appendChild(newGroupTitle); newGroupTitle = newGroupTitle.cloneNode(true); //克隆 newGroupTitle.innerText = "InGame"; child_InGame.appendChild(newGroupTitle); for (let i = 0; i < jqobj.length; i++) { let cur = jqobj.get(i); let profileID = cur.getAttribute("data-steamid"); //-------------------------------------------------------------------- SpecialName = undefined; steamName = undefined; // if (document.URL.indexOf("/friends") == -1) { //如果是在个人资料页面 // //获取备注 // var SpecialNameobj = document.getElementsByClassName("nickname"); //nickname // SpecialName = undefined; // if (SpecialNameobj != "undefined") { // SpecialName = SpecialNameobj[0].innerText; //备注 // } // //获取steam名称 // steamName = document.getElementsByClassName("actual_persona_name")[0].innerText; //steam名称 // name = steamName; // } else //否则如果是好友界面 //{ //获取名称,然后判断是备注还是steam名称 var SpecialNameobj = cur.getElementsByClassName("friend_block_content"); var nicknameObj = cur.getElementsByClassName("player_nickname_hint"); SpecialName = undefined; var OfflineTime = SpecialNameobj[0].getElementsByClassName("friend_last_online_text"); var strOfflineTime = ""; var nYear = "0", nMonth = "0", nDay = "0", nHours = "0", nMinutes = "0", nSeconds = "0"; var strData = ""; if (OfflineTime.length > 0) //找到了 { strOfflineTime = OfflineTime[0].innerText.slice(5); //去掉‘上次在线’字符串 var strOfflineTimeArr = strOfflineTime.split(' '); strOfflineTimeArr[strOfflineTimeArr.length - 1] = strOfflineTimeArr[strOfflineTimeArr.length - 1].slice(0, -1); //去掉最后的‘前’字符串 //console.log("strOfflineTime",strOfflineTime,strOfflineTimeArr); for (let i = 0; i < strOfflineTimeArr.length; i += 2) { if (strOfflineTimeArr[i + 1] == "年") nYear = strOfflineTimeArr[i]; else if (strOfflineTimeArr[i + 1] == "月") nMonth = strOfflineTimeArr[i]; else if (strOfflineTimeArr[i + 1] == "天") nDay = strOfflineTimeArr[i]; else if (strOfflineTimeArr[i + 1] == "小时") nHours = strOfflineTimeArr[i]; else if (strOfflineTimeArr[i + 1] == "分钟") nMinutes = strOfflineTimeArr[i]; else if (strOfflineTimeArr[i + 1] == "秒") nSeconds = strOfflineTimeArr[i]; } strData = nYear + '/' + nMonth + '/' + nDay + ' ' + nHours + ':' + nMinutes + ':' + nSeconds; //console.info("strData",strData); var hzWeek = new Array("日", "一", "二", "三", "四", "五", "六", "日"); function cweekday(wday) { return hzWeek[wday]; } function calaDay() { //计算时间差: 一个是当前时间,一个是相差的时间,就都转为秒数进行相减,再还原时间 var date = new Date(); ddd = parseInt(nDay); //转数字后取对应负数 //ttt = new Date(y, m - 1, d).getTime() + ddd * 24000 * 3600; ttt = date.getTime() + ~(ddd * 86400); theday = new Date(); theday.setTime(ttt); //document.getElementById("result1").innerHTML = theday.getFullYear() + "年" + (1 + theday.getMonth()) + "月" + theday.getDate() + "日" + "星期" + cweekday(theday.getDay()); return theday.getTime(); //获取对应的时间戳 } function calbHMS() { //计算时间差: 一个是当前时间,一个是相差的时间,就都转为秒数进行相减,再还原时间 var date = new Date(); var date1 = new Date(); var s = nHours * 3600 + nMinutes * 60 + nSeconds; // y2 = date.getYear(); // m2 = date.getMonth(); // d2 = date.getDay(); date1.setTime(date.getTime() + ~s); // y3 = document.getElementById("SY3").value; // m3 = document.getElementById("SM3").value; // d3 = document.getElementById("SD3").value; // day2 = new Date(y2, m2 - 1, d2); // day3 = new Date(y3, m3 - 1, d3); //document.getElementById("result2").innerHTML = (day3 - day2) / 86400000; return date1.getTime(); } var nS = 0; if (nDay > 0) { nS = calaDay() //console.log("calaDay(nDay):",nS); } else { nS = calbHMS() //console.log("calbHMS()",nS); } ArrOfflineTime.push([nS, i]); } //SpecialName = SpecialNameobj[0].innerText.slice(0, SpecialNameobj[0].innerText.indexOf("*")); //提取备注 //创建离线区和在线区 //遍历所有的好友,找到离线的好友,解析字符串,装入Date对象 //6个数字指定年、月、日、小时、分钟、秒(0) //没有的就写0 //获取毫秒数 dateObject.getTime() 或者用 Date.parse(datestring) // var d=new Date("5/05/11 1:10:0"); // document.write("从 1970/01/01 至今已有:" + d.getTime() + " 毫秒。"); // document.write("从 1970/01/01 至今已有:" + Date.parse("5/05/11 1:10:0") + " 毫秒。"); //存储在二维数组里,一个是毫秒数,一个是数组下标 //对秒数进行升序排序,然后取下标,对指定好友依次添加 //} //console.log("[Debug] name:", name); } //for //console.log(ArrOfflineTime); ArrOfflineTime.sort(function(a, b) { if (a[0] > b[0]) return 1; if (a[0] < b[0]) return -1; return 0; }); //对时间戳排序 //console.log(ArrOfflineTime); //遍历二维数组,然后取下标,对指定好友依次添加 for (let i = 0; i < ArrOfflineTime.length; i++) { child_Offline.appendChild(jqobj[ArrOfflineTime[i][1]]); //.getElementsByClassName("friend_block_content").parentNode } //将游戏中和在线的好友也添加到分组里 var jqobj1 = jQuery("#search_results .selectable.online"); //选择在线的好友 var jqobj2 = jQuery("#search_results .selectable.in-game"); //选择游戏中的好友 var jqobj3 = jQuery("#search_results .selectable.golden"); //选择金色的好友 for (let i = 0; i < jqobj3.length; i++) { var strGame = jqobj3[i].getElementsByClassName("friend_small_text")[0].innerText; var game = strGame.replace(/^\s+|\s+$/g, ""); //去除两边的空格 //console.log("strGame"); if (game == "") { //console.log("在线"); child_Online.appendChild(jqobj3[i]); } else { //console.log(game); child_InGame.appendChild(jqobj3[i]); } } for (let i = 0; i < jqobj1.length; i++) { child_Online.appendChild(jqobj1[i]); } for (let i = 0; i < jqobj2.length; i++) { child_InGame.appendChild(jqobj2[i]); } GroupMode = 2; } } }); await jQuery("#ShowFriendData").click(async function() { //显示好友详细数据(不可用) traverseAllFriend(); //遍历所有好友 }); if((window.location.origin + window.location.pathname).indexOf('/groups') != -1){ //去除参数和锚点后的url jQuery("#comment_submit_special").unbind("click"); //取消绑定点击事件 jQuery("#comment_submit_special").click(async function() { layer.alert("目前还没有完善,请使用旁边第一个按钮!)",{icon: 0}); return; }); //document.getElementById('group_tab_content_overview').style.display = "block"; //显示 //InitGroupPage // if ( window.location.hash ) //锚点被提取 // { // initial_group_url = window.location.hash.substr( 1 ); // } // history.replaceState //锚点被清除 //$('group_tab_content_overview').hide(); //UI被隐藏 jQuery("#comment_submit").unbind("click"); //取消绑定点击事件 jQuery("#comment_submit").click(async function() { //组留言 var postUrl = "https://steamcommunity.com/comment/Clan/post/"; //发布 var delUrl = "https://steamcommunity.com/comment/Clan/delete/"; //删除 var endUrl = "/-1/"; //结尾 const newMgs= jQuery("#comment_textarea").val(); //获取评论内容 var jqObj = jQuery('.group_block.selected'); var total = jqObj.length; if (total > 0) //选择的朋友总数 { jQuery("#log_head, #log_body").html(""); var jqobj = jQuery("#search_results .selectable.offline"); //选择离线的好友 //遍历所有节点,向盒子里添加节点 for (let i = 0; i < total; i++) { var idStr = jqObj[i].getElementsByClassName('groupMemberStat linkStandard steamLink')[0].href; var id = idStr.slice(idStr.indexOf('\'')+1,idStr.lastIndexOf('\'')); //id var link = jqObj[i].getElementsByClassName('linkTitle')[0].href; //组链接 var anchorName = "/#commentthread_Clan_" + id + "_area"; //锚点名称 var name = jqObj[i].getElementsByClassName('linkTitle')[0].innerText; //名称 (function(i, id) { //setTimeout(function() { jQuery.post(postUrl + id + endUrl, { comment: newMgs, count: 6, sessionid: g_sessionID, feature2: -1 }, function(response) { if (response.success === false) { jQuery("#log_body")[0].innerHTML += "<a style='color:#ff2c85;' target='_blank' href=\"" + link + "\">" + '[' + (i + 1) + '/' + total + '] 留言失败了! ' + name + ' ' + response.error + "</a><br>"; } else { jQuery("#log_body")[0].innerHTML += '[' + (i + 1) + '/' + total + '] ' + "成功发表评论于 <a target='_blank' href=\"" + link + "\">" + name + "</a>" + "<span> → </span><a style='color:#FB7299;' target='_blank' href=\"" + (link + anchorName) + "\">" + newMgs + "</a><br>"; } }).fail(function() { jQuery("#log_body")[0].innerHTML += '<span style="color:#DA2626;">[' + (i + 1) + '/' + total + '] ' + "无法发表评论于 <a style='color:#DA2626;' target='_blank' href=\"" + link + "\">" + name + "</a></span><br>"; }).always(function() { jQuery("#log_head").html("<br><b>当前处理了 " + (i + 1) + "个, 总计 " + total + " 个组.<b>"); }); //}, i * 6000); })(i, id); await sleep(3000); } } }); } } /** * app.js */ class App{ /** * 主程序运行环境初始化 * @param {Object} yunMode 运行模式: 保留,当前未使用 */ constructor(yunMode) { //初始化 资源(必要) if(gc_res == null) gc_res = new resource(); //初始化 UI(必要) if(gc_menu_friends_ui == null) gc_menu_friends_ui = new menu_friends_ui(); //您的好友 if(gc_menu_friends_invite_ui == null) gc_menu_friends_invite_ui = new menu_friends_invite_ui(); //待处理邀请 if(gc_menu_shielding_ui == null) gc_menu_shielding_ui = new menu_shielding_ui(); //已屏蔽 if(gc_menu_gameFriend_ui == null) gc_menu_gameFriend_ui = new menu_gameFriend_ui(); //近期共同游戏的玩家 if(gc_menu_liveAdmin_ui == null) gc_menu_liveAdmin_ui = new menu_liveAdmin_ui(); //直播版主 if(gc_menu_following_Players_ui == null) gc_menu_following_Players_ui = new menu_following_Players_ui(); //关注的玩家 if(gc_menu_groups_ui == null) gc_menu_groups_ui = new menu_groups_ui(); //您的组 if(gc_menu_groups_invite_ui == null) gc_menu_groups_invite_ui = new menu_groups_invite_ui(); //待处理邀请 //初始化 外部API(可选) if(gc_exApis == null) gc_exApis = new externalApis(); //初始化 拓展功能(测试) // if(!gc_steamdb) // { // gc_steamdb = new SteamDB(); // gc_steamdb.getFreeGameInfo(); // } // if(!gc_ai) // { // gc_ai = new intelligenceAI(); // gc_ai.getWeather('北京'); // } return (async () => { await this._runtimeInit(); //运行环境初始化 return this; // Return the newly-created instance }).call(this); } async _runtimeInit(){ //运行环境初始化 await gc_res.init(true); } _lazyInit(){ //延迟初始化 var customUrl = ""; var profileID = getBaseInfo(0); if(gc_friAct == null) gc_friAct = new friendActivity(profileID || customUrl); } /* 初始化应用程序 */ async init(type){ //0.读取错误信息数据库,检查是否需要进行恢复 //1.读取存储数据库 //2.准备基本运行环境 var url = window.location.origin + window.location.pathname; //window.location.href //去除参数和锚点后的url //https://steamcommunity.com/id/miku-39/friends?l=english#state_online => https://steamcommunity.com/id/miku-39/friends if(URLs.g_friendUrlRegExp.test(url)){ console.log("重新构建UI-您的好友."); if(gc_menu_friends_ui && typeof gc_menu_friends_ui.initUI === 'function') return await gc_menu_friends_ui.initUI(true); //调用回调s } else if(URLs.g_otherUrlRegExp1_1.test(url)){ console.log("不处理-添加好友."); //不处理 return false; } else if(URLs.g_otherUrlRegExp1_2.test(url)){ console.log("不处理-好友待处理邀请."); //暂时 不处理 return false; } else if(URLs.g_otherUrlRegExp1_3.test(url)){ console.log("重新构建UI-已屏蔽."); if(gc_menu_shielding_ui && typeof gc_menu_shielding_ui.initUI === 'function') return await gc_menu_shielding_ui.initUI(true); //调用回调 } else if(URLs.g_otherUrlRegExp1_4.test(url)){ console.log("不处理-近期共同游戏的玩家."); //暂时 不处理 return false; } else if(URLs.g_otherUrlRegExp1_5.test(url)){ console.log("重新构建UI-直播版主."); if(gc_menu_liveAdmin_ui && typeof gc_menu_liveAdmin_ui.initUI === 'function') return await gc_menu_liveAdmin_ui.initUI(true); //调用回调 } else if(URLs.g_otherUrlRegExp2_1.test(url)){ console.log("重新构建UI-关注的玩家."); if(gc_menu_following_Players_ui && typeof gc_menu_following_Players_ui.initUI === 'function') return await gc_menu_following_Players_ui.initUI(true); //调用回调 } else if(URLs.g_otherUrlRegExp2_2.test(url)){ console.log("重新构建UI-您的组."); //window.location.reload(false); //重新加载当前页面 if(gc_menu_groups_ui && typeof gc_menu_groups_ui.initUI === 'function') return await gc_menu_groups_ui.initUI(true); //调用回调 } else if(URLs.g_otherUrlRegExp2_3.test(url)){ console.log("不处理UI-组待处理邀请!"); //window.location.reload(false); //重新加载当前页面 //暂时 不处理 return false; } // else if(URLs.g_otherUrlRegExp3.test(url)){ // console.log("重新构建UI-您的好友."); // if(gc_menu_friends_ui && typeof gc_menu_friends_ui.initUI === 'function') // return await gc_menu_friends_ui.initUI(true); //调用回调s // } } /* 运行应用程序 //方式: 内置, 悬浮窗口 => "internal", "window" //语言: 重新设置要加载的语言 ==> 参考 g_languageList 对象 */ async run(){ //0.前置准备 //1.创建应用程序UI //2.注册应用程序事件 // (async()=>{ // console.log("异步加载绘制资源.."); // await gc_res._loadDrawResources();//异步加载绘制资源 // })(); var url = window.location.origin + window.location.pathname; //window.location.href //去除参数和锚点后的url //https://steamcommunity.com/id/miku-39/friends?l=english#state_online => https://steamcommunity.com/id/miku-39/friends if(URLs.g_friendUrlRegExp.test(url)){ console.log("重新构建UI-您的好友."); if(gc_menu_friends_ui && typeof gc_menu_friends_ui.initUI === 'function') return await gc_menu_friends_ui.createUI(); //调用回调 } else if(URLs.g_otherUrlRegExp1_1.test(url)){ console.log("不处理-添加好友."); //不处理 return false; } else if(URLs.g_otherUrlRegExp1_2.test(url)){ console.log("不处理-好友待处理邀请."); //暂时 不处理 return false; } else if(URLs.g_otherUrlRegExp1_3.test(url)){ console.log("重新构建UI-已屏蔽."); if(gc_menu_shielding_ui && typeof gc_menu_shielding_ui.initUI === 'function') return await gc_menu_shielding_ui.createUI(); //调用回调 } else if(URLs.g_otherUrlRegExp1_4.test(url)){ console.log("不处理-近期共同游戏的玩家."); //暂时 不处理 return false; } else if(URLs.g_otherUrlRegExp1_5.test(url)){ console.log("重新构建UI-直播版主."); if(gc_menu_liveAdmin_ui && typeof gc_menu_liveAdmin_ui.initUI === 'function') return await gc_menu_liveAdmin_ui.createUI(); //调用回调 } else if(URLs.g_otherUrlRegExp2_1.test(url)){ console.log("重新构建UI-关注的玩家."); if(gc_menu_following_Players_ui && typeof gc_menu_following_Players_ui.initUI === 'function') return await gc_menu_following_Players_ui.createUI(); //调用回调 } else if(URLs.g_otherUrlRegExp2_2.test(url)){ console.log("重新构建UI-您的组."); //window.location.reload(false); //重新加载当前页面 if(gc_menu_groups_ui && typeof gc_menu_groups_ui.initUI === 'function') return await gc_menu_groups_ui.createUI(); //调用回调 } else if(URLs.g_otherUrlRegExp2_3.test(url)){ console.log("不处理UI-组待处理邀请!"); //window.location.reload(false); //重新加载当前页面 //暂时 不处理 return false; } // else if(URLs.g_otherUrlRegExp3.test(url)){ // console.log("重新构建UI-您的好友."); // gc_menu_friends_ui && typeof gc_menu_friends_ui.initUI === 'function' && return await gc_menu_friends_ui.createUI(); //调用回调s // } } /* 停止应用程序运行 //级别: 注销当前事件和UI 停止脚本运行, +还原改动, +释放资源 => "stop", "reModify", "releReSource" //方式: 内置, 悬浮窗口 => "internal", "window" */ stop(rank){ // } /* 重新运行应用程序 //级别: 从缓存重新加载, 从服务器重新加载, 只重新加载,不运行脚本 => "reLoadCache", "reLoadServer", "onlyLoad" //方式: 内置, 悬浮窗口 => "internal", "window" */ async reRun(rank){ } /* 设置显示模式 //模式: 显示, 隐藏 => "show", "hide" //方式: 内置, 悬浮窗口 => "internal", "window" */ setShowMode(showMode = "show", showType = "internal"){ } /* 设置窗口参数 //位置: Position: x, y => css单位 //大小: Size: width, height => css单位 //背景透明度: 百分比 => 0~1 //是否描绘边框: bool => true, false //是否显示标题栏: bool => true, false */ reSetWindow(posX, posY, width, height, alpha = 1, isShowBorder = true, isShowTitleBar = true){ } } (async()=>{ gc_app = await new App(); if(await gc_app.init(true) != false){ await gc_app.run(); } })();