uniapp插件无广告下载导入(Dclound插件下载)

旨在帮助用户在无法看广告的情况下跳过广告直接下载

このスクリプトの質問や評価の投稿はこちら通報はこちらへお寄せください。
// ==UserScript==
// @name         uniapp插件无广告下载导入(Dclound插件下载)
// @namespace    https://dreamlove.top
// @license MIT
// @version      1.0
// @description  旨在帮助用户在无法看广告的情况下跳过广告直接下载
// @author       QiuYe
// @match        https://ext.dcloud.net.cn/plugin?*
// @icon         
// @require      https://code.jquery.com/jquery-3.6.0.min.js
// @require      https://code.jquery.com/ui/1.12.1/jquery-ui.min.js
// @resource     jQueryUICSS https://code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css
// ==/UserScript==

(function () {
  "use strict";
  const $ = jQuery.noConflict(true);
  // 添加jQuery UI的CSS样式
  var link = document.createElement("link");
  link.rel = "stylesheet";
  link.type = "text/css";
  link.href = "https://code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css";
  document.getElementsByTagName("head")[0].appendChild(link);

  // 创建导入按钮
  function createInputButton() {
    // 创建按钮元素
    var $newButton = $(
      '<button id="import-button-qiuye"><span class="icon">📥</span>(免广告)导入插件</button>'
    );

    // 设置按钮的样式
    $newButton.css({
      width: "240px",
      "background-color": "#28a745", // 绿色背景
      color: "white", // 白色文字
      padding: "10px 20px", // 内边距
      border: "none", // 无边框
      "border-radius": "20px", // 圆角
      "font-size": "16px", // 字体大小
      cursor: "pointer", // 鼠标悬停时显示为指针
      display: "flex", // 使用flex布局
      "align-items": "center", // 垂直居中对齐
      "justify-content": "center", // 水平居中对齐
      margin: "10px", // 添加一些外边距
    });

    // 设置图标的样式
    $newButton.find(".icon").css({
      "margin-right": "10px", // 图标与文字之间的间距
      "font-size": "18px", // 图标字体大小
    });

    // 添加按钮悬停和点击时的样式
    $newButton.hover(
      function () {
        $(this).css("background-color", "#218838"); // 更深的绿色
      },
      function () {
        $(this).css("background-color", "#28a745"); // 恢复原始绿色
      }
    );

    $newButton.mousedown(function () {
      $(this).css("background-color", "#1e7e34"); // 更深的绿色
    });

    $newButton.mouseup(function () {
      $(this).css("background-color", "#218838"); // 恢复悬停绿色
    });

    return $newButton;
  }

  // 创建下载按钮
  function createDownloadButton() {
    // 创建按钮元素
    var $button = $(
      '<button id="download-button-qiuye"><span class="icon">⬇️</span>(免广告)下载插件ZIP</button>'
    );

    // 设置按钮的样式
    $button.css({
      width: "240px",
      "background-color": "#007bff", // 蓝色背景
      color: "white", // 白色文字
      padding: "10px 20px", // 内边距
      border: "none", // 无边框
      "border-radius": "20px", // 圆角
      "font-size": "16px", // 字体大小
      cursor: "pointer", // 鼠标悬停时显示为指针
      display: "flex", // 使用flex布局
      "align-items": "center", // 垂直居中对齐
      "justify-content": "center", // 水平居中对齐
      margin: "10px", // 添加一些外边距
    });

    // 设置图标的样式
    $button.find(".icon").css({
      "margin-right": "10px", // 图标与文字之间的间距
      "font-size": "18px", // 图标字体大小
    });

    // 添加按钮悬停和点击时的样式
    $button.hover(
      function () {
        $(this).css("background-color", "#0069d9"); // 更深的蓝色
      },
      function () {
        $(this).css("background-color", "#007bff"); // 恢复原始蓝色
      }
    );

    $button.mousedown(function () {
      $(this).css("background-color", "#0056b3"); // 更深的蓝色
    });

    $button.mouseup(function () {
      $(this).css("background-color", "#0069d9"); // 恢复悬停蓝色
    });

    return $button;
  }

  // 从 plugin-id 元素的 span 标签中提取插件ID
  function getPluginId() {
    var pluginIdText = $(".plugin-id span").text();
    var match = pluginIdText.match(/插件ID:(.+)/);
    return match ? match[1] : null;
  }

  // 从类名为 "plugin-name" 下的 h3 标签获取文本内容
  function getTextFromPluginName() {
    // 选择类名为 "plugin-name" 下的 h3 标签,并获取其文本内容
    var text = $(".plugin-name h3")
      .text()
      .replace(/[\n\s]/g, ""); // 获取文本并去除首尾空格和换行符
    return text; // 返回提取到的文本内容
  }

  // 选择类名为 "plugin-more-info" 的最后一个 div 元素,并获取其文本内容
  function getVersionFromPluginMoreInfo() {
    var text = $(".plugin-more-info div:last-of-type").text(); // 获取文本并去除首尾空格和换行符
    // 使用正则表达式匹配 "版本:" 后面的内容
    var match = text.match(/版本:(.+)/);
    // 如果匹配成功,则返回匹配到的版本号,否则返回空字符串
    return match ? match[1] : "";
  }

  function getSizeFromPluginSize() {
    // 选择类名为 "plugin-size" 的 span 元素,并获取其文本内容
    var text = $(".plugin-size span").text().trim(); // 获取文本并去除首尾空格和换行符
    // 使用正则表达式匹配体积大小
    var match = text.match(/插件包体积:(.+)/);
    // 如果匹配成功,则返回匹配到的体积大小,否则返回空字符串
    return match ? match[1] : "";
  }
  function getImageSrcWithRegex(regex = /\w+-\w+-\w+-\w+-\w+/) {
    var matchingPart = null; // 初始化一个变量来保存匹配到的部分内容

    $("img").each(function () {
      var src = $(this).attr("src");
      var match = src.match(regex);
      if (match) {
        // 匹配到特定格式的内容
        matchingPart = match[0]; // 将匹配到的部分内容保存到matchingPart变量中
        return false; // 中断循环
      }
    });

    // 返回匹配到的部分内容
    if (matchingPart !== null) {
      // 如果匹配到了内容,去除末尾的 "_0"
      matchingPart = matchingPart.slice(0, -2);
    }
    return matchingPart;
  }

  // 导入函数
  function executeImportFunction() {
    var baseURL = "hbuilderx://requestExtension/uni_modules?plugin";
    var uidPlug = getImageSrcWithRegex();
    var pluginId = getPluginId();
    var namePlug = getTextFromPluginName();
    var versionPlug = getVersionFromPluginMoreInfo();
    var sizePlug = getSizeFromPluginSize();
    console.log(
      "222222222222222",
      uidPlug,
      pluginId,
      namePlug,
      versionPlug,
      sizePlug
    );
    if (!pluginId) {
      alert("无法获取插件ID");
      return;
    }
    if (!namePlug) {
      alert("无法获取插件名称");
      return;
    }
    if (!versionPlug) {
      alert("无法获取插件版本");
      return;
    }
    if (!sizePlug) {
      alert("无法获取插件包体积");
      return;
    }
    if (!uidPlug) {
      alert("无法获取插件UID,插件可能是免费的");
      return;
    }
    var params = {
      id: pluginId,
      name: namePlug,
      version: versionPlug,
      download_url: `https://ext-resource-t.dcloud.net.cn/marketplace/${uidPlug}/${versionPlug}/plugin.zip`,
      size: sizePlug,
      category_id: 21,
      description: "",
      platforms: [],
      is_uniModules: 1,
      extends: false,
      type: "source",
      is_free: 1,
      is_uniappx: 0,
      only_uniappx: 0,
    };
    var url = baseURL + "=" + encodeURIComponent(JSON.stringify(params));
    console.log("创建的url", url);
    var $a = $("<a>", {
      href: url, // 确保 URL 是完整的
      target: "_blank", // 在新标签页中打开
    });

    // 将 <a> 标签添加到 body 中
    $a.appendTo("body");

    // 使用原生的 JavaScript click 方法触发点击事件
    $a[0].click();

    // 移除 <a> 标签
    $a.remove();
  }

  // 下载函数
  function executeDownloadFunction() {
    var uidPlug = getImageSrcWithRegex();
    var versionPlug = getVersionFromPluginMoreInfo();
    if (!uidPlug) {
      alert("无法获取插件UID,插件可能是免费的");
      return;
    }
    if (!versionPlug) {
      alert("无法获取插件版本");
      return;
    }
    var url = `https://ext-resource-t.dcloud.net.cn/marketplace/${uidPlug}/${versionPlug}/plugin.zip`;
    var $a = $("<a>", {
      href: url, // 确保 URL 是完整的
      target: "_blank", // 在新标签页中打开
    });

    // 将 <a> 标签添加到 body 中
    $a.appendTo("body");

    // 使用原生的 JavaScript click 方法触发点击事件
    $a[0].click();

    // 移除 <a> 标签
    $a.remove();
  }
  // 等待页面加载完成
  $(document).ready(function () {
    var $newButton = createInputButton(); // 创建导入按钮
    var $downloadButton = createDownloadButton(); // 创建下载按钮

    $newButton.prependTo(".banner .download");
    $downloadButton.prependTo(".banner .download");
    // 创建对话框的div元素
    var $dialog = $("<div>", {
      id: "confirmDialog",
      title: "是否继续操作",
      text: "本插件目的是为了避免广告看不到导致无法下载插件的问题,如果有空,请尽量看广告支持作者!(确认后插件只显示一次)",
    })
      .appendTo("body")
      .dialog({
        autoOpen: false,
        modal: true,
        buttons: {
          确认: function () {
            $(this).dialog("close");
            localStorage.setItem("dcloud__confirm__read", "true");
            executeImportFunction();
          },
          取消: function () {
            $(this).dialog("close");
          },
        },
      });

    // 导入按钮点击事件
    $("#import-button-qiuye").click(function () {
      if (localStorage.getItem("dcloud__confirm__read") === "true") {
        // 如果localStorage中已经存储了确认信息,直接执行函数
        executeImportFunction();
      } else {
        // 否则显示确认对话框
        $("#confirmDialog").dialog("open");
      }
    });

    // 下载按钮点击事件
    $("#download-button-qiuye").click(function () {
      if (localStorage.getItem("dcloud__confirm__read") === "true") {
        // 如果localStorage中已经存储了确认信息,直接执行函数
        executeDownloadFunction();
      } else {
        // 否则显示确认对话框
        $("#confirmDialog").dialog("open");
      }
    });
  });
})();