Greasy Fork

Greasy Fork is available in English.

Steam、Epic历史价格查询

跳转到SteamDB、EpicGamesDB

当前为 2024-06-01 提交的版本,查看 最新版本

// ==UserScript==
// @name         Steam、Epic历史价格查询
// @description  跳转到SteamDB、EpicGamesDB
// @author       shopkeeperV
// @namespace    http://greasyfork.icu/zh-CN/users/150069
// @version      1.0.6
// @run-at       document-end
// @match        https://store.steampowered.com/*
// @match        https://store.epicgames.com/*
// @grant        window.onurlchange
// @grant        GM_info
// ==/UserScript==

(function () {
    'use strict';
    let host = location.host;
    let path = location.pathname;
    let db_url;
    if (/steampowered/.test(host)) {
        let page_type;
        let title_eles;
        if (/app/.test(path)) {
            page_type = "app";
            title_eles = document.getElementsByClassName("apphub_AppName");
            let wrappers = document.getElementsByClassName("game_area_purchase_game_wrapper");
            for (let wrapper of wrappers) {
                let item_type;
                let item_id;
                let form = wrapper.getElementsByTagName("form")[0];
                let inputs = form.getElementsByTagName("input");
                for (let input of inputs) {
                    if (/subid|bundleid/.test(input.name)) {
                        if (/subid/.test(input.name)) {
                            item_type = "sub";
                        } else if (/bundleid/.test(input.name)) {
                            item_type = "bundle";
                        }
                        item_id = input.value;
                        break;
                    }
                }
                db_url = "https://steamdb.info/" + item_type + "/" + item_id + "/#pricehistory";
                wrapper.getElementsByTagName("h1")[0].appendChild(createASpan(db_url));
            }
        } else {
            if (/sub/.test(path)) {
                page_type = "sub";
            } else if (/bundle/.test(path)) {
                page_type = "bundle";
            } else return;
            title_eles = document.getElementsByClassName("pageheader");
        }
        let page_id = path.match(/\/([0-9]*?)\//i)[1];
        for (let title_ele of title_eles) {
            db_url = "https://steamdb.info/" + page_type + "/" + page_id + "/#pricehistory";
            title_ele.appendChild(createASpan(db_url));
        }
    }
    if (/epicgames/.test(host)) {
        let loop_times = 0;
        let url = location.href.split("#")[0];
        handler();
        if (/xmonkey|tampermonkey/i.test(GM_info.scriptHandler)) {
            window.addEventListener('urlchange', () => {
                console.log("Epic历史价格查询:监听到地址变化。");
                handler();
            });
        } else {
            listenURLChange();
        }

        function listenURLChange() {
            if (url !== location.href.split("#")[0]) {
                handler();
                url = location.href.split("#")[0];
            }
            setTimeout(() => {
                listenURLChange();
            }, 500);
        }

        function handler() {
            if (loop_times >= 30) {
                loop_times = 0;
                console.log("Epic历史价格查询:取消循环。");
                return;
            }
            if (/\/p\//.test(location.pathname)) {
                console.log("Epic历史价格查询:正在获取页面id...");
                let ele1 = document.getElementById("_schemaOrgMarkup-Product");
                let ele2 = document.getElementById("btn_age_continue");
                if (ele1 && !ele2 && !ele1.getAttribute("price_db")) {
                    ele1.setAttribute("price_db", "price_db");
                    loop_times = 0;
                    console.log("Epic历史价格查询:已添加查询按钮。");
                    let content = ele1.textContent;
                    let id = content.match(/"sku":"([^"]*):([^"]*)"/)[2];
                    db_url = "https://epicgamesdb.info/p/" + id + "/" + location.pathname.split("/").pop();
                    document.getElementsByTagName("h1")[0].appendChild(createASpan(db_url));
                } else {
                    loop_times++;
                    setTimeout(handler, 500);
                }
            }
        }
    }

    function createASpan(url) {
        let span = document.createElement("span");
        span.setAttribute("class", "history_price");
        span.textContent = "查价";
        span.style.cssText = "display:inline-block;margin-left:10px;color:yellow;cursor:pointer;";
        span.onclick = (e) => {
            window.open(url);
        };
        return span;
    }
})();