// ==UserScript== // @name 特殊自用 // @namespace http://tampermonkey.net/ // @version 1.0.17 // @description 功能一览: 2、微信公证号文章:内容左对齐;列表增加序号和斑马纹,便于阅读。 3、文本片段样式【最后:1、localStorage中,支持配置】 4、本地web 127.0.0.1 补全favicon图标=> 囍;查看本地目录路径时,增加 favicon📂、斑马纹、限宽 4、阿里云发布流水线日期 // @author Enjoy // @icon https://foruda.gitee.com/avatar/1698283059572409586/4867929_enjoy_li_1698283059.png!avatar200 // @match *://*/* // @match file:///* // @grant GM_addElement // @grant GM_setClipboard // @license GPL License // 函数文档 https://www.tampermonkey.net/documentation.php#api:GM_addElement // @downloadURL none // ==/UserScript== /******/ (() => { // webpackBootstrap /******/ "use strict"; var __webpack_exports__ = {}; ;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/typeof.js function typeof_typeof(o) { "@babel/helpers - typeof"; return typeof_typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, typeof_typeof(o); } ;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js function _toPrimitive(input, hint) { if (typeof_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } ;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof_typeof(key) === "symbol" ? key : String(key); } ;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/defineProperty.js function defineProperty_defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } ;// CONCATENATED MODULE: ./tools/GM.js function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { defineProperty_defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } /** @描述 函数文档 https://www.tampermonkey.net/documentation.php#api:GM_addElement */ /** * @description 创建element * @export * @param {*} tag * @param {*} [options={}] * @param {*} [win=window] * @returns {*} */ function createElement(tag) { var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; var win = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : window; if (!win.GM_createElement) { win.GM_createElement = GM_createElement; } return GM_createElement(tag, options); /** * @param {*} tag * @param {*} options { * idPrefix = `enjoy_${ENV_CRX}_${tag}`, * el = 'html', * autoInsert = true, * randomType = 'single', * id = '', * addPrefix = true, * insertType = tag === 'style' ? 'appendChild' : 'prepend', * } * @returns {*} dom */ function GM_createElement(tag, options) { var _options$idPrefix = options.idPrefix, idPrefix = _options$idPrefix === void 0 ? "enjoy_".concat("SelfUseTools", "_").concat(tag, "_") : _options$idPrefix, _options$el = options.el, el = _options$el === void 0 ? 'html' : _options$el, _options$autoInsert = options.autoInsert, autoInsert = _options$autoInsert === void 0 ? true : _options$autoInsert, _options$randomType = options.randomType, randomType = _options$randomType === void 0 ? 'single' : _options$randomType, _options$id = options.id, id = _options$id === void 0 ? '' : _options$id, _options$addPrefix = options.addPrefix, addPrefix = _options$addPrefix === void 0 ? true : _options$addPrefix, _options$insertType = options.insertType, insertType = _options$insertType === void 0 ? tag === 'style' ? 'appendChild' : 'prepend' : _options$insertType; if (addPrefix) { id = "".concat(idPrefix).concat(id); } if (randomType !== 'single') { id = "".concat(id, "_").concat(Math.floor(Math.random() * 1000)); } options.id = id; var dom = document.querySelector("#".concat(id)); if (!dom) { dom = document.createElement(tag); } for (var key in options) { if (Object.hasOwnProperty.call(options, key) && key !== 'el') { dom[key] = options[key]; } } if (autoInsert) { if (typeof el === 'string') { el = document.querySelector(el); } //insertType prepend | appendChild el[insertType](dom); } return dom; } } /** @描述 是否匹配到目标url */ function isMatched() { var urls = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; var currentUrl = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : location.href; if (typeof urls === 'string') { urls = [urls]; } return !!urls.find(function (regUrl) { return new RegExp(regUrl).test(currentUrl); }); } function prependMetaUF8() { return document.querySelector('meta[charset="UTF-8"]') || createElement('meta', { charset: 'utf-8' }); } /** * @description doCopy 复制文本到剪贴板 * @export * @param {*} text */ function doCopy(text) { var _navigator; if (document.hasFocus() && (_navigator = navigator) !== null && _navigator !== void 0 && (_navigator = _navigator.clipboard) !== null && _navigator !== void 0 && _navigator.writeText) { // localhost、127.0.0.1或者https中才能正常使用 // 读取剪贴板 // navigator.clipboard.readText().then((clipText) => {console.log('clipText=',clipText)}) // 写入剪贴板 navigator.clipboard.writeText(text)["catch"](function (err) { return console.error("clipboard.writeText\uFF1A".concat(err)); }); return; } var textarea = document.createElement('textarea'); document.body.appendChild(textarea); textarea.value = text; textarea.select(); document.execCommand('Copy'); setTimeout(function () { textarea.remove(); }, 1000); } /** * 检测element元素的可见性,即 非display:none * @param {*} element * @returns {*} {Boolean} */ function checkVisibility(element) { if (element.checkVisibility) { return element.checkVisibility(); } return !!element.offsetParent; } /** * @description 创建element的提示 * @export * @param {*} [options={}] * @returns {*} */ function createElementTipFn() { var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var _options$setTimeoutSt = options.setTimeoutStep, setTimeoutStep = _options$setTimeoutSt === void 0 ? 1000 : _options$setTimeoutSt, _options$backgroundCo = options.backgroundColors, backgroundColors = _options$backgroundCo === void 0 ? { warn: 'rgb(181 156 51 / 60%)', success: 'rgb(3 113 3 / 60%)', error: 'rgb(165 2 2 / 60%)', info: 'rgb(67 62 62 / 60%)' } : _options$backgroundCo, _options$color = options.color, color = _options$color === void 0 ? '#ffffff' : _options$color, _options$opacity = options.opacity, opacity = _options$opacity === void 0 ? 1 : _options$opacity; var setTimeoutStamp = 0; return function createElementTip() { var configs = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var content = configs.content, e = configs.e, _configs$type = configs.type, type = _configs$type === void 0 ? 'info' : _configs$type, _configs$tagType = configs.tagType, tagType = _configs$tagType === void 0 ? 'span' : _configs$tagType; if (!content) return; console.log("content => %O ", content); clearTimeout(setTimeoutStamp); var contentDom = createElement(tagType, { id: 'createElementTip', innerText: content, style: "\n font-size:14px;\n font-weight:600;\n color:".concat(color, ";\n position: fixed;\n left: ").concat(numbericalInterval(e.clientX - 46), "px;\n top: ").concat(numbericalInterval(e.clientY - 30, [5, window.innerHeight - 35]), "px;\n background-color:").concat(backgroundColors[type], ";\n opacity: ").concat(opacity, ";\n border-radius: 4px;\n padding: 4px 8px;\n box-shadow:0 0 5px 0 rgb(255 255 255 / 60%) inset;\n pointer-event:none;\n z-index:").concat((Math.floor(Date.now() / 1000) + '').slice(-5), ";\n\t\t\t\t\t\tdisplay:inline-block;\n ") }); setTimeoutStamp = setTimeout(function () { // contentDom.remove() contentDom.style.display = 'none'; }, setTimeoutStep); }; } /** * @description dom是否可编辑 * @param {*} [dom=document.activeElement] * @returns {*} {boolean} */ function isContentEditableOfDOM() { var dom = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : document.activeElement; if (dom.tagName === 'INPUT' || dom.tagName === 'TEXTAREA') { return !dom.disabled; } else { return !!findParentElement(dom, function (dom) { return dom.contentEditable === 'true'; }, null); } } /** * @description 数字区间 * @param {*} val * @param {*} [interval=[10, window.innerWidth]] * @returns {*} */ function numbericalInterval(val) { var interval = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [5, window.innerWidth - 130]; var indexStart = interval[0]; var indexEnd = interval[1]; if (val < indexStart) return indexStart; if (val > indexEnd) return indexEnd; return val; } /** * @description 可滚动的dom * @param {*} dom * @returns {*} */ function findHasScrollbarDom(dom) { if (!(dom instanceof HTMLElement)) { console.warn("\u53EF\u6EDA\u52A8\u7684dom\u51FD\u6570 findHasScrollbarDom:\u53C2\u6570dom\u5FC5\u987B\u4E3Aelement\u5143\u7D20 "); return void 0; } while (dom) { if (dom.offsetHeight < dom.scrollHeight && !(window.getComputedStyle(dom).overflowY == 'visible' || window.getComputedStyle(dom).overflowY == 'hidden')) { break; } dom = dom.parentElement; } if (!dom || dom === document.body) { // 始终是 documentElement等同于window dom = document.documentElement; } console.warn("\u9875\u9762\u6EDA\u52A8\u5143\u7D20\u7684tagName: ", dom.tagName.toLocaleLowerCase(), 'dom.className:', dom.className); return dom; } /** * @description 获取方法配置 * @param {string} [key=''] * @param {*} [defaultOpt={ includedUrls: [] }] * @returns {*} {Object} **/ function getSettingFromLocalStorage() { var _localStorage, _localStorage2; var fileName = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; var defaultOpt = arguments.length > 1 ? arguments[1] : undefined; var mergedSettingOpt = _objectSpread({ runType: '0', includedUrls: [], excludeUrls: [] }, defaultOpt); var fullSettingKey = "enjoy_setting"; var fullSettings = (_localStorage = localStorage) !== null && _localStorage !== void 0 && _localStorage[fullSettingKey] ? JSON.parse((_localStorage2 = localStorage) === null || _localStorage2 === void 0 ? void 0 : _localStorage2[fullSettingKey]) : {}; var SETTING = _objectSpread(_objectSpread({}, mergedSettingOpt), fullSettings === null || fullSettings === void 0 ? void 0 : fullSettings[fileName]); fullSettings[fileName] = SETTING; fullSettings.runTypeDest = undefined; fullSettings.instructions = "\n\u4E00\u3001\u5339\u914D\u89C4\u5219\u4F18\u5148\u7EA7\uFF1Aruntype > * > excludedUrls > includedUrls\n\u4E8C\u3001runType\u662F\u9488\u5BF9\u5728\u5F53\u524D\u57DF\u540D\u89C4\u5219\uFF1A0(\u9ED8\u8BA4\u6267\u884C\u5339\u914D\u89C4\u5219)\uFF1B1(\u5F3A\u5236\u6267\u884C,\u5373\u8DF3\u8FC7\u5339\u914D\u89C4\u5219)\uFF1B2(\u4E0D\u6267\u884C)\n"; localStorage[fullSettingKey] = JSON.stringify(fullSettings || {}); return SETTING; } /** * @description 是否执行该方法 * @param {*} [settingOpt={}] * @returns {*} {Boolean} */ function isExcutableBySetting() { var settingOpt = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var runType = settingOpt.runType, _settingOpt$excludeUr = settingOpt.excludeUrls, excludeUrls = _settingOpt$excludeUr === void 0 ? [] : _settingOpt$excludeUr, _settingOpt$includedU = settingOpt.includedUrls, includedUrls = _settingOpt$includedU === void 0 ? [] : _settingOpt$includedU; if (runType == '1') return true; if (runType == '2') return false; var HREF = location.href; if (excludeUrls !== null && excludeUrls !== void 0 && excludeUrls.length && isMatched(excludeUrls, HREF)) { return false; } if ((includedUrls === null || includedUrls === void 0 ? void 0 : includedUrls.length) === 0) return true; var findOne = isMatched(includedUrls, HREF); return !!findOne; } /** * @description 是否不执行 * @param {String} fileName * @param {Object} settingOpt * @returns {Boolean} */ function codeIsNotExcutable(fileName, settingOpt) { try { // logSettingOptWithColor() var setting = getSettingFromLocalStorage(fileName, settingOpt); return _objectSpread({ notExcutable: !isExcutableBySetting(setting) }, setting); } catch (error) { // base64路径下,禁用storage console.error(error); return _objectSpread({ notExcutable: true }, settingOpt); } } /** * @description 彩色打印 * @param {string} [key='enjoy_setting'] */ function logSettingOptWithColor(key) { var dataKey = 'is-log-of-enjoy'; if (true) return; // if (document.body.getAttribute(dataKey)) return document.body.setAttribute(dataKey, '1'); // clearTimeout(window.EnjoyColorLogTimer || 0) window.EnjoyColorLogTimer = setTimeout(function () { var _key; (_key = key) !== null && _key !== void 0 ? _key : key = 'enjoy_setting'; var SETTINGS = JSON.parse(localStorage[key] || '{}'); console.log("%c\uD83D\uDC47 ".concat(key, " \u8BBE\u7F6E\u53C2\u6570\uFF1A"), 'background:#4e0ab780;color:#fff;', '\n', SETTINGS, "\n\nkeyNameList:", Object.keys(SETTINGS)); console.log("%c\uD83D\uDC47\u81EA\u5B9A\u4E49\u914D\u7F6E\uFF0C\u4EE3\u7801\u5982\u4E0B\uFF1A", 'background:#4e0ab747;color:#fff;', "\n\u5F53\u524D\u57DF\u540D\u4E0B\u662F\u5426\u8FD0\u884C\u76F8\u5E94\u51FD\u6570,", "\n\u8BBE\u7F6ErunType(1\u3001\u5F3A\u5236\u8FD0\u884C\uFF1B2\u3001\u4E0D\u8FD0\u884C)\u3002", '\n\n', modifyRuntype.toString(), "\nmodifyRuntype('keyName',2)"); }, 3 * 1000); } /** * @description 修改运行机制 * @export * @param {string} keyName * @param {0|1|2} runType */ function modifyRuntype(keyName, runType) { var keyOfSETTINGS = 'enjoy_setting'; var SETTINGS = JSON.parse(localStorage[keyOfSETTINGS] || '{}'); if (!SETTINGS[keyName]) return; SETTINGS[keyName].runType = runType || 2; localStorage[keyOfSETTINGS] = JSON.stringify(SETTINGS); } /** * @description 查找特定条件的父级元素 * @export * @param {Element} dom * @param {Function} callback * @param {Element} [defaultVal=document.documentElement] * @returns {Element} */ function findParentElement(dom, callback) { var defaultVal = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : document.documentElement; if (!(dom instanceof HTMLElement)) { console.warn("\u67E5\u627E\u7279\u5B9A\u6761\u4EF6\u7684\u7236\u7EA7\u5143\u7D20\u51FD\u6570 findParentElement:\u53C2\u6570dom\u5FC5\u987B\u4E3Aelement\u5143\u7D20 "); return void 0; } while (dom) { if (callback(dom)) { break; } dom = dom.parentElement; } if (!dom || dom === document.body) { // 始终是 documentElement等同于window dom = defaultVal; } return dom; } /** 原生横向滚动条 吸附 页面底部 */ var StickyHorizontalNativeScrollBar = /*#__PURE__*/(/* unused pure expression or super */ null && (_createClass(function StickyHorizontalNativeScrollBar() { var _this = this; var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; _classCallCheck(this, StickyHorizontalNativeScrollBar); /** 创建滚轴组件元素 */ _defineProperty(this, "createScrollbar", function () { var style = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; if (_this.scrollbar) return _this.scrollbar; var timer = Date.now(); _this.thumbId = "thumb".concat(timer); _this.scrollbarId = "scrollbar".concat(timer); _this.scrollbar = document.createElement('div'); _this.scrollbar.setAttribute('id', _this.scrollbarId); _this.scrollbar.innerHTML = "\n\t\t\t\n\t\t\t
\n\t\t"); }); /** 把滚轴组件元素插入目标元素的后面 */ _defineProperty(this, "insertScrollbar", function (el) { _this.target = el; if (typeof el === 'string') { _this.target = document.querySelector(el); } if (!_this.target) throw Error('el Dom do not exit'); _this.targetParentElement = document.querySelector(el).parentElement; if (!_this.targetParentElement.querySelector("#".concat(_this.scrollbarId))) { _this.targetParentElement.insertBefore(_this.scrollbar, _this.target.nextSibling); } return _this.target; }); /** 设置 滚轴组件元素尺寸 */ _defineProperty(this, "setScrollbarSize", throttle(function () { _this.scrollbar.style.width = _this.target.clientWidth + 'px'; _this.scrollbar.querySelector("#".concat(_this.thumbId)).style.width = _this.target.scrollWidth + 'px'; }, 100)); /** 监听目标元素和滚轴元素的scroll和页面resize事件 */ _defineProperty(this, "onEvent", function () { _this.target.addEventListener('scroll', _this.onScrollTarget); _this.scrollbar.addEventListener('scroll', _this.onScrollScrollbar); window.addEventListener('resize', _this.setScrollbarSize); }); /** 移除事件 */ _defineProperty(this, "removeEvent", function () { _this.target.removeEventListener('scroll', _this.onScrollTarget); _this.scrollbar.removeEventListener('scroll', _this.onScrollScrollbar); window.removeEventListener('resize', _this.setScrollbarSize); }); _defineProperty(this, "onScrollTarget", throttle(function (e) { _this.scrollbar.scrollLeft = e.target.scrollLeft; }, 100)); _defineProperty(this, "onScrollScrollbar", throttle(function (e) { _this.target.scrollLeft = e.target.scrollLeft; }, 100)); var _el = options.el, _options$style = options.style, _style = _options$style === void 0 ? '' : _options$style; this.createScrollbar(_style); this.insertScrollbar(_el); this.setScrollbarSize(); this.onEvent(); }))); /** 插入横向滚动条 */ var HorizontalScrollBar = /*#__PURE__*/(/* unused pure expression or super */ null && (function () { function HorizontalScrollBar() { var _this2 = this; var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; _classCallCheck(this, HorizontalScrollBar); /** 创建滚轴组件元素 */ _defineProperty(this, "createScrollbar", function (setStyle) { if (_this2.scrollbar) return _this2.scrollbar; var timer = Date.now(); _this2.scrollbarId = "scrollbar".concat(timer); _this2.scrollbar = document.createElement('div'); _this2.scrollbar.setAttribute('data-part', 'scrollbar'); _this2.scrollbar.setAttribute('id', _this2.scrollbarId); _this2.scrollbar.innerHTML = "\n\t\t".concat(setStyle(_this2.scrollbarId) || _this2.setDefaultStyle(_this2.scrollbarId), "\n\t\t\n\t\t"); }); /** 把滚轴组件元素插入目标元素的后面 */ _defineProperty(this, "insertScrollbar", function (el) { _this2.target = el; if (typeof el === 'string') { _this2.target = document.querySelector(el); } if (!_this2.target) throw Error('el Dom do not exit'); _this2.targetParentElement = document.querySelector(el).parentElement; if (!_this2.targetParentElement.querySelector("#".concat(_this2.scrollbarId))) { _this2.targetParentElement.insertBefore(_this2.scrollbar, _this2.target.nextSibling); } return _this2.target; }); /** 根据目标元素 设置 滚轴组件元素尺寸 */ _defineProperty(this, "setScrollbarSize", function () { _this2.scrollbar.style.width = _this2.target.clientWidth + 'px'; _this2.thumb = _this2.scrollbar.querySelector('[data-part="thumb"]'); _this2.thumb.style.width = _this2.scrollbar.clientWidth * _this2.target.clientWidth / _this2.target.scrollWidth + 'px'; _this2.offsetMax = _this2.scrollbar.clientWidth - _this2.thumb.clientWidth; _this2.rate = (_this2.target.scrollWidth - _this2.target.clientWidth) / _this2.offsetMax; }); /** */ _defineProperty(this, "onMouseDownOfThumb", function (e) { console.log("mousedown => %O "); _this2.prePageX = e.pageX; _this2.isMousedown = true; }); /** */ _defineProperty(this, "onMouseUpOfWindow", function (e) { _this2.isMousedown = false; }); /** */ _defineProperty(this, "requestAnimationFrameCallback", function (offsetLeft) { _this2.thumb.style.left = offsetLeft + 'px'; _this2.target.scrollLeft = offsetLeft * _this2.rate; }); /** */ _defineProperty(this, "onMousemoveOfWindow", function (e) { if (_this2.isMousedown) { var offsetLeft = Number(_this2.thumb.style.left.replace('px', '')) + Number(e.pageX - _this2.prePageX); offsetLeft = Math.max(0, offsetLeft); offsetLeft = Math.min(offsetLeft, _this2.offsetMax); _this2.requestAnimationFrameCallback(offsetLeft); _this2.prePageX = e.pageX; } }); /** 监听目标元素和滚轴元素的scroll和页面resize事件 */ _defineProperty(this, "onEvent", function () { _this2.thumb.addEventListener('mousedown', _this2.onMouseDownOfThumb); window.addEventListener('mouseup', _this2.onMouseUpOfWindow); window.addEventListener('mousemove', _this2.onMousemoveOfWindow); window.addEventListener('resize', _this2.setScrollbarSize); }); /** 移除事件 */ _defineProperty(this, "removeEvent", function () { _this2.thumb.removeEventListener('mousedown', _this2.onMouseDownOfThumb); window.removeEventListener('mouseup', _this2.onMouseUpOfWindow); window.removeEventListener('mousemove', _this2.onMousemoveOfWindow); window.removeEventListener('resize', _this2.setScrollbarSize); }); var _el2 = options.el, _options$setStyle = options.setStyle, _setStyle = _options$setStyle === void 0 ? function () { return null; } : _options$setStyle; this.createScrollbar(_setStyle); this.insertScrollbar(_el2); this.setScrollbarSize(); this.onEvent(); } _createClass(HorizontalScrollBar, [{ key: "setDefaultStyle", value: function setDefaultStyle(scrollbarId) { return "\n\t\t\n\t"); } }]); return HorizontalScrollBar; }())); /** 持久化数据状态 */ var PersistentStorage = /*#__PURE__*/(/* unused pure expression or super */ null && (function () { function PersistentStorage() { var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; _classCallCheck(this, PersistentStorage); var _options$valKey = options.valKey, valKey = _options$valKey === void 0 ? 'valKey' : _options$valKey, _options$storageType = options.storageType, storageType = _options$storageType === void 0 ? 'sessionStorage' : _options$storageType; this.valKey = valKey; this.storageType = storageType; } _createClass(PersistentStorage, [{ key: "write", value: function write(val) { val = _typeof(val) === 'object' ? JSON.stringify(val) : val; val && window[this.storageType].setItem(this.valKey, val); } }, { key: "read", value: function read() { var val = window[this.storageType].getItem(this.valKey); return val ? JSON.parse(val) : val; } }, { key: "remove", value: function remove() { window[this.storageType].removeItem(this.valKey); } }]); return PersistentStorage; }())); /** * @description 节流函数 * @export * @param {Function} func * @param {Number} [wait=100] * @returns {Function} */ function throttle(func) { var wait = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 100; var isDoing = false; return function () { if (isDoing) return; isDoing = true; func.apply(void 0, arguments); setTimeout(function () { isDoing = false; }, wait); }; } /** * @description 防抖函数 * @export * @param {Function} func * @param {Number} [wait=100] * @param {'end'|'front'} type * @returns {Function} */ function debounce(func) { var wait = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 100; var type = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'end'; var timer = 0; return function () { clearTimeout(timer); for (var _len = arguments.length, rest = new Array(_len), _key2 = 0; _key2 < _len; _key2++) { rest[_key2] = arguments[_key2]; } timer = setTimeout.apply(void 0, [func, wait].concat(rest)); }; } /** * @description 等候 * @export * @param {number} [interval=17] * @returns {Promise} */ function awaitTime() { var interval = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 17; return new Promise(function (resolve) { setTimeout(resolve, interval); }); } /** * @description 打开已在窗口仅激活,不刷新 * @export * @class OpenPlus */ var OpenPlus = /*#__PURE__*/(/* unused pure expression or super */ null && (_createClass(function OpenPlus() { var _this3 = this; var opt = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; _classCallCheck(this, OpenPlus); _defineProperty(this, "openPre", function () { var callback = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : function () { return null; }; for (var _len2 = arguments.length, rest = new Array(_len2 > 1 ? _len2 - 1 : 0), _key3 = 1; _key3 < _len2; _key3++) { rest[_key3 - 1] = arguments[_key3]; } var win = _this3.open.apply(_this3, rest); callback === null || callback === void 0 || callback(); return win; }); _defineProperty(this, "open", function (href) { var willOpenTab = _this3.win.tabsCacheOfOpenPlus[href]; for (var _len3 = arguments.length, rest = new Array(_len3 > 1 ? _len3 - 1 : 0), _key4 = 1; _key4 < _len3; _key4++) { rest[_key4 - 1] = arguments[_key4]; } if (willOpenTab === undefined) { var _this3$win; willOpenTab = (_this3$win = _this3.win).open.apply(_this3$win, [href].concat(rest)); _this3.win.nextOfOpenPlus.forEach(function (item) { return item === null || item === void 0 ? void 0 : item(); }); return _this3.win.tabsCacheOfOpenPlus[href] = willOpenTab; } else if (willOpenTab.closed === true) { var _this3$win2; return (_this3$win2 = _this3.win).open.apply(_this3$win2, [href].concat(rest)); } else if (willOpenTab.closed === false) { willOpenTab.focus(); return willOpenTab; } }); var _opt$win = opt.win, _win = _opt$win === void 0 ? window : _opt$win, _opt$next = opt.next, next = _opt$next === void 0 ? function () { return null; } : _opt$next; this.win = _win; this.win.tabsCacheOfOpenPlus = this.win.tabsCacheOfOpenPlus || {}; this.win.nextOfOpenPlus = this.win.nextOfOpenPlus || []; this.win.nextOfOpenPlus.push(next); }))); function modifyStorage() { var opt = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var _opt$storageName = opt.storageName, storageName = _opt$storageName === void 0 ? 'localStorage' : _opt$storageName, chainKeys = opt.chainKeys, _opt$doType = opt.doType, doType = _opt$doType === void 0 ? 'get' : _opt$doType, val = opt.val, _opt$prefix = opt.prefix, prefix = _opt$prefix === void 0 ? 'enjoy_setting' : _opt$prefix; if (prefix) { chainKeys = "".concat(prefix, ".").concat(chainKeys); } chainKeys = chainKeys.split('.'); var keyOfLevel1 = chainKeys.shift(); var keyOfEnd = chainKeys.pop(); var isObject = true; var storage = null; try { storage = JSON.parse(window[storageName][keyOfLevel1]); } catch (error) { isObject = false; storage = window[storageName][keyOfLevel1]; console.error("".concat(storageName, " ").concat(chainKeys, " \u4E00\u7EA7\u5C5E\u6027\u503C\u4E3A\u57FA\u672C\u7C7B\u578B")); return; } var obj = storage; chainKeys.forEach(function (key) { obj = obj[key]; }); if (doType === 'set') { obj[keyOfEnd] = val; window[storageName][keyOfLevel1] = JSON.stringify(storage); } else { return obj[keyOfEnd]; } } /** * @description 简便的Storage SimpleStorage({ prefix: 'prefix' }) * @param {*} opt */ function storagex() { var opt = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var Storage = /*#__PURE__*/_createClass(function Storage() { var _this4 = this; var opt = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; _classCallCheck(this, Storage); _defineProperty(this, "storage", null); _defineProperty(this, "setItem", function (keys, val) { _this4.formatChainKeys(keys); _this4.getFirstLevelVal(); _this4.chainVal('set', val); return void 0; }); _defineProperty(this, "getItem", function (keys) { _this4.formatChainKeys(keys); _this4.getFirstLevelVal(); return _this4.chainVal('get'); }); _defineProperty(this, "removeItem", function (keys) { _this4.formatChainKeys(keys); _this4.getFirstLevelVal(); return _this4.chainVal('remove'); }); _defineProperty(this, "clear", function () { var keysWithPrefix = Object.keys(_this4.storage).filter(function (item) { return item.startsWith(_this4.prefix); }); keysWithPrefix.forEach(function (key) { return _this4.storage.removeItem(key); }); return void 0; }); _defineProperty(this, "getFirstLevelVal", function () { var state = _this4.storage[_this4.prefix + _this4.startKey]; try { state = JSON.parse(state); } catch (error) {} _this4.cache = state; return state; }); _defineProperty(this, "formatChainKeys", function (keys) { keys = keys.split('.'); _this4.startKey = keys.shift(); _this4.endKey = keys.pop(); _this4.middlekeys = keys; return keys; }); _defineProperty(this, "chainVal", function (doType, val) { var obj = _this4.cache; _this4.middlekeys.forEach(function (key) { obj = obj[key]; }); if (doType === 'set') { if (_this4.endKey) { obj[_this4.endKey] = val; } else { _this4.cache = val; } _this4.storage.setItem(_this4.prefix + _this4.startKey, _this4.isObject(_this4.cache) ? JSON.stringify(_this4.cache) : _this4.cache); } else if (doType === 'get') { if (_this4.endKey) { return obj[_this4.endKey]; } return _this4.cache; } else if (doType === 'remove') { if (_this4.endKey) { var isDeleted = delete obj[_this4.endKey]; isDeleted && _this4.setItem(_this4.startKey, _this4.cache); return isDeleted; } _this4.storage.removeItem(_this4.prefix + _this4.startKey); } }); _defineProperty(this, "isObject", function (value) { var type = _typeof(value); return value != null && (type === 'object' || type === 'function'); }); var prefix = opt.prefix, storage = opt.storage; this.prefix = prefix ? "".concat(prefix, "_") : ''; this.storage = storage; }); if (opt.storage && sessionStorage.__proto__.setItemX) return opt.storage; var storage = new Storage(opt); if (opt.storage) return storage; if (sessionStorage.__proto__.setItemX) return; sessionStorage.__proto__.setItemX = function (key, val) { storage.storage = this; storage.setItem(key, val); }; sessionStorage.__proto__.getItemX = function (key) { storage.storage = this; return storage.getItem(key); }; sessionStorage.__proto__.removeItemX = function (key) { storage.storage = this; return storage.removeItem(key); }; sessionStorage.__proto__.clearX = function () { storage.storage = this; return storage.clear(); }; } /** * @description 处理标记内容 * @param {*} opt * @returns {*} */ function operateComment(opt) { var _opt$text = opt.text, text = _opt$text === void 0 ? '' : _opt$text, _opt$S = opt.S, S = _opt$S === void 0 ? '/*' : _opt$S, _opt$E = opt.E, E = _opt$E === void 0 ? '*/' : _opt$E, _opt$modify = opt.modify, modify = _opt$modify === void 0 ? function (val) { return val; } : _opt$modify; var stack = []; var index = text.indexOf(S); if (index === -1) return text; while (index <= text.length - 1) { if (text[index] + text[index + 1] == S) { stack.push(index); } else if (text[index] + text[index + 1] == E) { var latestIndex = stack.pop(); if (latestIndex !== undefined) { var middle = modify(text.slice(latestIndex + S.length, index)); text = text.slice(0, latestIndex) + middle + text.slice(index + S.length); index = latestIndex + middle.length; } } index++; } return text; } /** 添加动画函数 */ function addAnimation(dom, className) { if (!dom || !className) return; if (!dom.animationend) { dom.animationend = function () { dom.classList.remove(className); }; } dom.removeEventListener('animationend', dom.animationend); dom.addEventListener('animationend', dom.animationend); dom.classList.add(className); } // 判断当前浏览器运行环境 function getBrowserEnv() { var userAgent = window.navigator.userAgent.toLowerCase(); var agents = ['Android', 'iPhone', 'SymbianOS', 'Windows Phone', 'iPad', 'iPod']; // 是否为支付宝环境 var isAliPay = /alipayclient/.test(userAgent); // 是否为淘宝环境 var isTaoBao = /windvane/.test(userAgent); // 是否为企业微信环境 var isWxWork = /wxwork/.test(userAgent); // 是否为微信环境 var isWeChat = /micromessenger/.test(userAgent) && !isWxWork; // 是否为移动端 var isPhone = agents.some(function (x) { return new RegExp(x.toLocaleLowerCase()).test(userAgent); }); return { isAliPay: isAliPay, isTaoBao: isTaoBao, isWxWork: isWxWork, isWeChat: isWeChat, isPhone: isPhone }; } var RegisterDbltouchEvent = /*#__PURE__*/(/* unused pure expression or super */ null && (function () { function RegisterDbltouchEvent(el, fn) { _classCallCheck(this, RegisterDbltouchEvent); this.el = el || window; this.callback = fn; this.timer = null; this.prevPosition = {}; this.isWaiting = false; // 注册click事件,注意this指向 this.el.addEventListener('click', this.handleClick.bind(this), true); } _createClass(RegisterDbltouchEvent, [{ key: "handleClick", value: function handleClick(evt) { var _this5 = this; var pageX = evt.pageX; var pageY = evt.pageY; if (this.timer) { clearTimeout(this.timer); this.timer = null; } if (!evt.isTrusted) { return; } if (this.isWaiting) { this.isWaiting = false; var diffX = Math.abs(pageX - this.prevPosition.pageX); var diffY = Math.abs(pageY - this.prevPosition.pageY); // 如果满足位移小于10,则是双击 if (diffX <= 10 && diffY <= 10) { // 取消当前事件传递,并派发1个自定义双击事件 evt.stopPropagation(); evt.target.dispatchEvent(new PointerEvent('dbltouch', { cancelable: false, bubbles: true })); // 也可以采用回调函数的方式 this.callback && this.callback(evt); } } else { this.prevPostion = { pageX: pageX, pageY: pageY }; // 阻止冒泡,不让事件继续传播 evt.stopPropagation(); // 开始等待第2次点击 this.isWaiting = true; // 设置200ms倒计时,200ms后重新派发当前事件 this.timer = setTimeout(function () { _this5.isWaiting = false; evt.target.dispatchEvent(evt); }, 200); } } }]); return RegisterDbltouchEvent; }())); /**移动端 双击 */ function addDbltouch() { var dom = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : window; var handle = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : function (event) { console.log('双击', event, Date.now()); }; var preTimestamp = 0; dom.addEventListener('click', function (event) { var currentTimestamp = Date.now(); if (currentTimestamp - preTimestamp < 200) handle(event); preTimestamp = currentTimestamp; }); } ;// CONCATENATED MODULE: ./src/tool/notaryNumberUI.js function run() { if (codeIsNotExcutable('notaryNumberUI', { name: '微信公证号', feature: '1、微信公证号布局,支持左右调整和持久化,以便为图片预览腾出操作空间;2、列表项目li标签增加序号和斑马纹,便于阅读', includedUrls: ['mp.weixin.qq.com'] }).notExcutable) return; modifyUI(); } function modifyUI() { // 微信公众号 createElement('style', { id: 'notaryNumberUI', innerHTML: "\n\t\t\thtml {\n\t\t\t\tmax-width: 667px !important;\n\t\t\t}\n\n\t\t\t/* .rich_media_area_primary_inner */\n\t\t\tspan,\n\t\t\tp {\n\t\t\t\tfont-size: 14px !important;\n\t\t\t}\n\n\t\t\tol,\n\t\t\tul {\n\t\t\t\tpadding-left: 50px !important;\n\t\t\t\tlist-style-type: decimal !important;\n\t\t\t}\n\n\t\t\tol > li:nth-child(2n),\n\t\t\tul > li:nth-child(2n) {\n\t\t\t\tbackground: rgb(0 0 0/ 5%);\n\t\t\t}\n\n\t\t\t/* \u53BB\u9664\u8DF3\u8F6C\u63A8\u8350\u9605\u8BFB\u8FDE\u63A5\u540E\u7684\u8499\u5C42 */\n\t\t\t.weui-mask,\n\t\t\t.weui-mask + weui-dialog_link{\n\t\t\t\tdisplay: none;\n\t\t\t}\n\n\t\t\t/* \u5173\u6CE8\u516C\u8BC1\u53F7\u4E8C\u7EF4\u7801 */\n\t\t\t.not_in_mm .qr_code_pc{\n\t\t\t\tposition: fixed !important;\n\t\t\t\ttop:0;\n\t\t\t\tright:0;\n\t\t\t}\n\n\t\t\t/* \u5207\u6362\u5E03\u5C40\uFF1A\u53CC\u51FB\u6807\u9898 */\n\t\t\thtml.float_right{\n\t\t\t\tmargin-left:auto;\n\t\t\t}\n\n\t\t\thtml.float_right #js_pc_qr_code .qr_code_pc{\n right:auto;\n\t\t\t\tleft:0;\n\t\t\t}\n\n\t\t\t/* \u6807\u9898\u680F */\n\t\t\t#activity-name{\n position: sticky;\n top: 0;\n z-index: 2;\n background: #fff;\n\t\t\t\tpadding: 5px 0;\n\t\t\t\tbackground-image: linear-gradient(to top, transparent 0, rgba(0, 0, 0, .2) 8px, transparent 0);\n\t\t\t}\n\n\t\t\t#activity-name::after{\n\t\t\t\tcontent:'\u53CC\u51FB\u8C03\u6574\u5E03\u5C40';\n\t\t\t\tfont-size: 12px;\n\t\t\t\tcolor: #f5dde1;\n\t\t\t}\n\n\t\t\t/* */\n\t\t\t.mp_profile_iframe_wrp{\n\t\t\t\tdisplay:none;\n\t\t\t}\n\t\t\t.mp_profile_iframe_wrp~p{\n\t\t\t\tdisplay:none;\n\t\t\t}\n\t\t\t.rich_media_meta_nickname::after {\n\t\t\t\tcontent: '\u25C0 \u5355\u51FB\u67E5\u770B\u4E8C\u7EF4\u7801\u548C\u7B80\u4ECB' '';\n\t\t\t\tfont-size: 12px;\n\t\t\t\tcolor: #f5dde1;\n\t\t}\n\t\t.not_in_mm .qr_code_pc{\n\t\t\tdisplay:none;\n\t\t}\n\t\t\t" }, window); setTimeout(function () { var titleDom = document.querySelector('#activity-name'); titleDom.addEventListener('dblclick', function () { localStorage.Enjoy_layoutType = document.documentElement.classList.toggle('float_right'); }); }, 3 * 1000); // 持久化布局 if (localStorage.Enjoy_layoutType === 'true') { document.documentElement.classList.toggle('float_right'); } } ;// CONCATENATED MODULE: ./src/tool/textFragments.js function textFragments_run() { if (codeIsNotExcutable('textFragments', { name: '文本片段样式', feature: '文本片段(Text Fragment)允许你直接链接到 web 文档中的特定文本部分,而不需要作者使用 URL 片段中的特定语法对其进行注释 https://developer.mozilla.org/zh-CN/docs/Web/Text_fragments' }).notExcutable) return; textFragments_modifyUI(); } function textFragments_modifyUI() { // 微信公众号 createElement('style', { id: 'textFragments', innerHTML: "\n ::target-text {\n\t\t\t\tcolor: #fff !important;\n\t\t\t\tbackground-color: orangered !important;\n\t\t }\n\t\t\t" }, window); } ;// CONCATENATED MODULE: ./src/tool/addFaviconOfDevApi.js function addFaviconOfDevApi_run() { // 本地文件路径, 增加📂 icon if (location.href.toLocaleLowerCase().includes('file:///')) { createElement('link', { el: 'head', rel: 'shortcut icon', href: 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxOCIgaGVpZ2h0PSIxOCI+PHRleHQgeT0iMTUiIHg9Ii0yIj7wn5OCPC90ZXh0Pjwvc3ZnPg==', type: 'image/x-icon' }); // 本地文件 目录样式 createElement('style', { el: 'head', innerHTML: "\n\t\t\t#parentDirLinkBox~table {\n\t\t\t\tborder-collapse:separate;\n\t\t\t\tword-break: break-all;\n\t\t\t\tmax-width: 600px;\n\t\t\t}\n\n\t\t\t#parentDirLinkBox~table tbody tr:nth-child(2n+1) td{\n\t\t\t\tbackground-color: #eee;\n\t\t\t}\n\t\t\t" }); } if (codeIsNotExcutable('addFaviconOfDevApi', { name: '开发环境下创建favicon', feature: '127.0.0.1域名下增加,网页增加favicon和标题,便于区别非开发环境', includedUrls: ['127.0.0.1'] }).notExcutable) return; createFaviconElementInLocalhostIP(); modifyDocumentTitle(); } function createFaviconElementInLocalhostIP() { if (document.querySelector("link[rel*='icon'][href*='/']")) return; createElement('link', { el: 'head', rel: 'shortcut icon', href: 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNSIgaGVpZ2h0PSIxNSI+PHRleHQgeT0iMTMiIGZpbGw9InJlZCI+5ZuNPC90ZXh0Pjwvc3ZnPg==', type: 'image/x-icon' }); } function modifyDocumentTitle() { var _document$title; if (!((_document$title = document.title) !== null && _document$title !== void 0 && _document$title.includes('Document'))) return; document.title = '🌄🌔🌟🌈'; } ;// CONCATENATED MODULE: ./src/tool/aliyun.js function aliyun_run() { if (codeIsNotExcutable('aliyun', { name: '阿里云流水线', feature: '以时间生产默认流水线版本号', includedUrls: ['flow.aliyun.com/pipelines'] }).notExcutable) return; aliyun_modifyUI(); } function aliyun_modifyUI() { // 阿里云流水线 // let btn = createElement( // 'div', // { // id: 'aliyun', // el: 'body', // title: 'get Version.No', // innerHTML: ` // 🕖 // `, // }, // window // ) // btn.addEventListener('click',() => { // doCopy(new Date().toLocaleString()) // }) function setting() { var options = localStorage.getItemX('latest_deploy'); var branchDom = document.querySelector('[placeholder="可输入分支/标签"]'); var versionDom = document.querySelector('#product_version'); var backupDom = document.querySelector('[placeholder="输入运行备注"]'); console.log('回显值', options); if (options) { var emitKey = ''; for (var key in branchDom) { console.log(key); if (key.includes('__reactEventHandlers')) { emitKey = key; break; } } branchDom[emitKey].onChange({ target: { value: options.branch } }); versionDom[emitKey].onChange({ target: { value: new Date().toLocaleString() || options.version } }); backupDom[emitKey].onChange({ target: { value: options.backup } }); } else { options = {}; } var submitDom = document.querySelector('.next-dialog-footer .next-btn-primary'); if (submitDom) { submitDom.addEventListener('click', function () { options.branch = branchDom.value; // options.version = versionDom.value options.backup = backupDom.value; localStorage.setItemX('latest_deploy', options); }); } else { console.log('submitDom为空'); } } // setTimeout(() => { var yunXing = document.querySelector('.is-yunxiao.next-btn-primary:not(.next-btn-text)'); if (yunXing) { if (yunXing.getAttribute('data-addevent')) { console.log('添加了点击事件'); return; } yunXing.setAttribute('data-addevent', '1'); yunXing.addEventListener('click', function () { setTimeout(setting, 1000 * 2); }); console.log('添加了点击事件'); } else { console.warn('没有找到 运行 按钮'); } // },1000 * 3) } ;// CONCATENATED MODULE: ./src/tool/crxUI.js function crxUI_run() { if (codeIsNotExcutable('crxUI', { name: 'chrome 扩展文档', feature: 'chrome 扩展文档样式: 方法 和 参数类型', includedUrls: ['developer.chrome.com'] }).notExcutable) return; crxUI_modifyUI(); } function crxUI_modifyUI() { // 微信公众号 createElement('style', { id: 'crxUI', innerHTML: "\n\t\t.crxUI .viewport--desktop.color-scheme--light>.devsite-wrapper>*>.devsite-main-content>*>.devsite-article>.devsite-article-body.clearfix>.dcc-reference>*>.dcc-code-sections>.stack>.stack>*>.dcc-code-sections__label[id^=method-]{\n\t\t\t\tfont-size: 20px !important;\n\t\t}\n\t\t.crxUI [id^=method-]{\n\t\t\tbackground: #e8efde !important;\n\t\t\tfont-weight: 800 !important;\n\t }\n\t\t.crxUI .viewport--desktop.color-scheme--light>.devsite-wrapper>*>.devsite-main-content>*>.devsite-article>.devsite-article-body.clearfix>.dcc-reference>*>.dcc-code-sections>.stack>.stack>*>.dcc-code-sections__label[id^=method-]::after{\n\t\tcontent:\" \u2B50\"\n\t\t}\n\t\t.crxUI [id^=type-]{\n\t\t\t\t background: #d1e2f9 !important;\n\t\t\t\tfont-weight: 800 !important;\n\t\t}\n\n\t\th1.devsite-page-title::after {\n\t\t\tcontent: '\u53CC\u51FB\u70B9\u4EAE\u51FD\u6570\u6837\u5F0F';\n\t\t\tfont-size: 12px;\n\t\t\tcolor: #e8efde;\n\t\t\tmargin: 0 4px;\n\t }\n\t\t.crxUI h1.devsite-page-title::after{\n\t\t\tcontent: '\u53CC\u51FB\u5173\u95ED\u51FD\u6570\u6837\u5F0F';\n\t\t}\n\t\t\t" }, window); setTimeout(function () { var titleDom = document.querySelector('.devsite-page-title'); titleDom.addEventListener('dblclick', function () { localStorage.Enjoy_crxUIType = document.documentElement.classList.toggle('crxUI'); }); }, 3 * 1000); // 持久化布局 if (localStorage.Enjoy_crxUIType === 'true') { document.documentElement.classList.toggle('crxUI'); } } ;// CONCATENATED MODULE: ./src/SelfUseTools.js SelfUseTools_run(); function SelfUseTools_run() { // linkByNamedWin.run() linkByNamedWin, 1、命名链接:打开链接方式,总是以命名的新窗口,跳转同一个链接页面,只激活,不刷新 run(); textFragments_run(); addFaviconOfDevApi_run(); aliyun_run(); crxUI_run(); } /******/ })() ;