Sonkwo_Steam_Search

快捷搜索steam商店

目前为 2021-09-14 提交的版本。查看 最新版本

// ==UserScript==
// @name:zh-CN      杉果Steam快捷搜索
// @name            Sonkwo_Steam_Search
// @namespace       https://blog.chrxw.com/
// @supportURL      https://blog.chrxw.com/scripts.html
// @contributionURL https://afdian.net/@chr233
// @version         1.8
// @description     快捷搜索steam商店
// @description:zh-CN  快捷搜索steam商店
// @author          Chr_
// @license         AGPL-3.0
// @connect         steampowered.com
// @include         /https://www.sonkwo.com\/sku\/\d+/
// @include         /https://www.sonkwo.hk\/sku\/\d+/
// @require         https://gf.qytechs.cn/scripts/431430-search-steam-store/code/Search_Steam_Store.js
// @grant           GM_xmlhttpRequest
// @grant           GM_addStyle
// ==/UserScript==

(() => {
  'use strict';
  let GdivResult = null; //控件数组

  setTimeout(() => {
    const container = document.querySelector('div.main-content');
    container.addEventListener('DOMNodeInserted', ({ relatedNode }) => {
      const ele = document.querySelector('h5.typical-name-2') || document.querySelector('h3.typical-name-1');
      if (ele.querySelector('button.btnSearch') === null) {
        init(ele);
      }
    });
  }, 500);

  //显示搜索按钮
  function init(ele) {
    const keyword = ele.textContent.replace(/[-+=:;:;'"‘’“”]/g, ' ');
    const btnSearch = document.createElement('button');
    btnSearch.className = 'btnSearch';
    btnSearch.textContent = '🔎';
    btnSearch.addEventListener('mouseover', () => { btnSearch.textContent = '🔎 搜索Steam'; });
    btnSearch.addEventListener('mouseout', () => { btnSearch.textContent = '🔎'; });
    btnSearch.addEventListener('click', () => { showResult(keyword); });

    ele.appendChild(btnSearch);
    const divResult = document.createElement('div');
    divResult.className = 'divResult';
    ele.appendChild(divResult);

    GdivResult = divResult;
  }

  //显示搜索结果
  function showResult(keyword) {
    searchStore(keyword, 'CN')
      .then((result) => {
        GdivResult.innerHTML = '';
        if (result.length === 0) {
          const btnRst = document.createElement('button');
          btnRst.textContent = '【快速搜索无结果,点击前往steam搜索页】';
          btnRst.addEventListener('click', () => { window.open(`https://store.steampowered.com/search/?term=${keyword}`); });
          GdivResult.appendChild(btnRst);
          return;
        }
        result.forEach(({ appID, isBundle, appName, appPrice, appUrl, appImg }) => {
          const btnRst = document.createElement('button');
          btnRst.title = `${isBundle ? "bundle" : "app"}/${appID}`;
          btnRst.addEventListener('click', () => { window.open(appUrl); });

          const btnName = document.createElement('p');
          btnName.textContent = `${appName}【${appPrice}】`
          btnRst.appendChild(btnName);
          btnRst.appendChild(document.createElement('br'));

          const btnImg = new Image();
          btnImg.src = appImg;

          btnRst.appendChild(btnImg);
          GdivResult.appendChild(btnRst);
        });
      })
      .catch((reason) => {
        alert(reason);
      });
  }
})();


//CSS表
GM_addStyle(`
.divResult {
    top: -180px;
    position: relative;
    width: 100%;
    overflow-y: hidden;
    white-space: nowrap;
  }
  .divResult > button {
    cursor: pointer;
  }
  .divResult > button:not(:last-child) {
    margin-right: 5px;
  }
  .divResult > button > p {
    display: inline;
    margin-left: 6px;
  }
  .divResult > button > img {
    zoom: 1.5;
    margin-top: 2px;
  }
  .btnSearch {
    padding: 0 5px;
    margin-left: 5px;
  }

`);

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址