商品_价位段Top商品

云图扩展工具

// ==UserScript==
// @name         商品_价位段Top商品
// @namespace    http://tampermonkey.net/
// @version      1.1
// @description  云图扩展工具
// @author       siji-Xian
// @match        *://yuntu.oceanengine.com/yuntu_brand/product/segmentedMarketDetail/marketProduct?*
// @icon         https://lf3-static.bytednsdoc.com/obj/eden-cn/prhaeh7pxvhn/yuntu/yuntu-logo_default.svg
// @grant        none
// @license      MIT
// @require      https://lf26-cdn-tos.bytecdntp.com/cdn/expire-1-M/jquery/3.2.1/jquery.min.js
// @require      https://cdn.bootcss.com/moment.js/2.20.1/moment.min.js
// @require      https://greasyfork.org/scripts/404478-jsonexportexcel-min/code/JsonExportExcelmin.js?version=811266
// @require      https://greasyfork.org/scripts/455576-qmsg/code/Qmsg.js?version=1122361
// ==/UserScript==

(function () {
  "use strict";
  var new_element = document.createElement("link");
  new_element.setAttribute("rel", "stylesheet");
  new_element.setAttribute("href", "https://qmsg.refrain.xyz/message.min.css");
  document.body.appendChild(new_element);

  const button = document.createElement("div");
  button.textContent = "导出数据";
  Object.assign(button.style, {
    height: "34px",
    lineHeight: "var(--line-height, 34px)",
    alignItems: "center",
    color: "#FFF",
    background: "linear-gradient(60deg, rgb(95, 240, 225), rgb(47, 132, 254))",
    borderRadius: "5px",
    margin: "0 10px",
    fontSize: "13px",
    padding: "0 10px",
    cursor: "pointer",
    fontWeight: "500",
    position: "absolute",
    top: "10px",
    right: "10px",
    zIndex: "999"
  });
  button.addEventListener("click", urlClick);

  const getRequestOptions = {
    method: "GET",
    redirect: "follow",
  };


  //message.js
  let loadingMsg = null;

  let target_data = null;

  (function listen() {
    var origin = {
      open: XMLHttpRequest.prototype.open,
      send: XMLHttpRequest.prototype.send,
    };
    XMLHttpRequest.prototype.open = function (a, b) {
      this.addEventListener("load", replaceFn);
      origin.open.apply(this, arguments);
    };
    XMLHttpRequest.prototype.send = function (a, b) {
      origin.send.apply(this, arguments);
    };
    function replaceFn(obj) {
      if (this?._url?.slice(0, 49) == "/product_node/v2/api/industry/insightProductStats") {
        target_data = JSON.parse(obj?.target?.response);
      }
    }
  })();

  function appendDoc() {
    setTimeout(() => {
      var like_comment = document.querySelectorAll("body")[0];
      if (like_comment) {
        like_comment.append(button); //把按钮加入到 x 的子节点中
        return;
      }
      appendDoc();
    }, 1000);
  }
  appendDoc();

  function checkElement() {
    const targetElement = document.querySelector(".DrawerCloseBtn__CloseBtn-ciPfX.CLSfX");
    if (targetElement) {
      button.style.display = "block";
    } else {
      button.style.display = "none";
    }
  }

  const intervalId = setInterval(checkElement, 1000);

  function getData(e){
    let data = e.data.list.map(v=>{
        return {
            '商品名称':v.product.name,
            'ID':v.product.id,
            '销售金额':v.data.salesAmount.value,
            '销售量':v.data.salesVolune.value,
            '购买人数':v.data.purchaseUidCnt.value,
        }
    })

    expExcel(data)
  }

  function expExcel(data) {
    let title = document.querySelector(".DrillingChartDrawerContainer__SubTitle-kuqyDX.bvhnkz").innerHTML;
   
    let contrast = {
      '商品名称': '商品名称',
      'ID': 'ID',
      '销售金额': '销售金额',
      '销售量': '销售量',
      '购买人数': '购买人数'
    };

    let fileName = title;

    setTimeout(() => {
      let option = {};
      option.fileName = fileName; //文件名
      option.datas =[{
          sheetName: "",
          sheetData: data,
          sheetHeader: Object.keys(contrast),
          sheetFilter: Object.values(contrast),
          columnWidths: [], // 列宽
        }];
      var toExcel = new ExportJsonExcel(option);
      toExcel.saveExcel();
      setTimeout(() => {
        loadingMsg.close();
      }, 1000);
    }, 1000);
  }

  function urlClick() {
    if (target_data) {
        loadingMsg = Qmsg.loading("正在导出,请勿重复点击!");
        getData(target_data);
      } else {
        loadingMsg = Qmsg.error("数据加载失败,请重试");
      }
  }
})();