您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
阿里云云效辅助脚本
当前为
// ==UserScript== // @name 阿里云云效增强 // @namespace http://bmqy.net/ // @version 1.0.4 // @author bmqy // @description 阿里云云效辅助脚本 // @license ISC // @icon  // @match https://packages.aliyun.com/* // @grant GM_deleteValue // @grant GM_getValue // @grant GM_setValue // ==/UserScript== (function () { 'use strict'; var _GM_deleteValue = /* @__PURE__ */ (() => typeof GM_deleteValue != "undefined" ? GM_deleteValue : void 0)(); var _GM_getValue = /* @__PURE__ */ (() => typeof GM_getValue != "undefined" ? GM_getValue : void 0)(); var _GM_setValue = /* @__PURE__ */ (() => typeof GM_setValue != "undefined" ? GM_setValue : void 0)(); (function() { const app = { init: function() { this.delStorage(); this.checkboxOnClick(); this.pkgUploadFormOnAddEvent(); }, // 脚本存储数据key sotrageKey: "BmqyAliyunPackage", /** * 获取脚本存储数据值 * @returns {Object} */ getStorage: function() { return _GM_getValue(this.sotrageKey); }, /** * 设置脚本存储 * @param {Object} value 存储数据值 */ setStorage: function(value) { _GM_setValue(this.sotrageKey, value); }, /** * 清除脚本存储 * @param {Object} value 存储数据值 */ delStorage: function() { _GM_deleteValue(this.sotrageKey); }, /** * 更新制品上传表单 */ pkgUploadFormUpdate: function() { let _this = this; let $groupId = document.querySelector("#groupId"); let $artifactId = document.querySelector("#artifactId"); let $version = document.querySelector("#version"); if (_this.getStorage()) { $groupId.value = _this.getStorage().group; _this.reactInputEmit($groupId); $artifactId.value = _this.getStorage().artifact; _this.reactInputEmit($artifactId); $version.value = _this.getStorage().version; _this.reactInputEmit($version); } }, // js如何在外部改变react受控组件的状态量?参考:https://github.com/ILovePing/ILovePing.github.io/issues/22 reactInputEmit: function(element) { let event = new Event("input", { bubbles: true }); event.simulated = true; let tracker = element._valueTracker; if (tracker) { tracker.setValue(element); } element.dispatchEvent(event); }, // 监听当前选中的制品 checkboxOnClick: function() { let _this = this; document.body.addEventListener("click", (e) => { let $element = e.target; if ($element.classList.contains("next-checkbox-input")) { if ($element.checked) { let $parent = _this.getParent( $element, "next-table-row" ); _this.currentPackageUpdate($parent); } else { setTimeout(() => { let $checkboxList = document.querySelectorAll( ".next-table-row.selected" ); if ($checkboxList.length == 0) { _this.delStorage(); return false; } _this.currentPackageUpdate($checkboxList[0]); }, 200); } } }); }, // 更新本地存储值 currentPackageUpdate: function(element) { let _this = this; if (!element) return false; let $tr = element.querySelectorAll(".next-table-cell-wrapper"); let $GA = $tr[1], $ver = $tr[2]; let GAStr = $GA.innerText; let data = { group: GAStr.split(":")[0], artifact: GAStr.split(":")[1], version: _this.versionFormat($ver.innerText) }; _this.setStorage(data); }, versionFormat: function(version) { if (!version) return version; let arr = version.split("-"); let numberArr = arr[0].split("."); numberArr.forEach((e, i) => { if (i >= numberArr.length - 1) { numberArr[numberArr.length - 1] = ++e; } }); let out = numberArr.join("."); if (arr[1]) { out += "-SNAPSHOT"; } return out; }, /** * 监听制品上传表单加载完成 */ pkgUploadFormOnAddEvent: function() { let _this = this; let mos = new MutationObserver(function(mutations, observer) { for (const mutation in mutations) { if (Object.hasOwnProperty.call(mutations, mutation)) { const element = mutations[mutation]; if (element.target.classList.contains( "next-dialog-body" )) { _this.pkgUploadFormUpdate(); } } } }); mos.observe(document.body, { attributes: true, childList: true, subtree: true }); }, /** * 获取指定元素的目标父元素 * @param {Dom} element * @param {String} className * @returns Dom[] */ getParent: function(element, className) { if (!element || !className) { return false; } let _this = this; while (element.parentNode) { element = element.parentNode; if (element.classList && element.classList.contains(className)) { return element; } _this.getParent(element, className); } return null; } }; app.init(); })(); })();