- // ==UserScript==
- // @name 边读边看图
- // @namespace http://tampermonkey.net/
- // @version 0.8.70
- // @description 功能一览:1、图文对照: 双击把图片固定在页面上,同时支持缩放、移动功能,便于图文对照阅读; 2、图片背景图: 使用浏览器查看在线图片或本地图片时,增加页面背景图,以便清晰显示当前图片轮廓 3、命名链接:打开链接方式,总是以命名的新窗口,跳转同一个链接页面,只激活,不刷新;4、快捷链接:点击链接文本时,跳转相应链接页面;5、鼠标选完文字后,(0.5秒内)立马松开左键,自动复制文字;反之,保持鼠标不移动超过 0.5秒后再松开,不会复制文字; 6、一键复制代码块:鼠标悬浮代码块后,点击显示的红色边框,复制到剪贴板 7、CSDN:仅在主动触发登录时,显示登录弹层 【最后:1、localStorage中,支持配置】
- // @author Enjoy
- // @icon https://foruda.gitee.com/avatar/1698283059572409586/4867929_enjoy_li_1698283059.png!avatar200
- // @match *://*/*
- // @match file:///*
- // @exclude *localhost*
- // @grant GM_addElement
- // @grant GM_setClipboard
- // @license GPL License
- // 函数文档 https://www.tampermonkey.net/documentation.php#api:GM_addElement
- // @homepageURL https://greasyfork.org/zh-CN/scripts/456560
- // ==/UserScript==
-
- /******/ (() => { // webpackBootstrap
- /******/ var __webpack_modules__ = ({
-
- /***/ 342:
- /***/ ((module, __unused_webpack_exports, __webpack_require__) => {
-
- var _typeof = (__webpack_require__(882)["default"]);
- function _regeneratorRuntime() {
- "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */
- module.exports = _regeneratorRuntime = function _regeneratorRuntime() {
- return e;
- }, module.exports.__esModule = true, module.exports["default"] = module.exports;
- var t,
- e = {},
- r = Object.prototype,
- n = r.hasOwnProperty,
- o = Object.defineProperty || function (t, e, r) {
- t[e] = r.value;
- },
- i = "function" == typeof Symbol ? Symbol : {},
- a = i.iterator || "@@iterator",
- c = i.asyncIterator || "@@asyncIterator",
- u = i.toStringTag || "@@toStringTag";
- function define(t, e, r) {
- return Object.defineProperty(t, e, {
- value: r,
- enumerable: !0,
- configurable: !0,
- writable: !0
- }), t[e];
- }
- try {
- define({}, "");
- } catch (t) {
- define = function define(t, e, r) {
- return t[e] = r;
- };
- }
- function wrap(t, e, r, n) {
- var i = e && e.prototype instanceof Generator ? e : Generator,
- a = Object.create(i.prototype),
- c = new Context(n || []);
- return o(a, "_invoke", {
- value: makeInvokeMethod(t, r, c)
- }), a;
- }
- function tryCatch(t, e, r) {
- try {
- return {
- type: "normal",
- arg: t.call(e, r)
- };
- } catch (t) {
- return {
- type: "throw",
- arg: t
- };
- }
- }
- e.wrap = wrap;
- var h = "suspendedStart",
- l = "suspendedYield",
- f = "executing",
- s = "completed",
- y = {};
- function Generator() {}
- function GeneratorFunction() {}
- function GeneratorFunctionPrototype() {}
- var p = {};
- define(p, a, function () {
- return this;
- });
- var d = Object.getPrototypeOf,
- v = d && d(d(values([])));
- v && v !== r && n.call(v, a) && (p = v);
- var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p);
- function defineIteratorMethods(t) {
- ["next", "throw", "return"].forEach(function (e) {
- define(t, e, function (t) {
- return this._invoke(e, t);
- });
- });
- }
- function AsyncIterator(t, e) {
- function invoke(r, o, i, a) {
- var c = tryCatch(t[r], t, o);
- if ("throw" !== c.type) {
- var u = c.arg,
- h = u.value;
- return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) {
- invoke("next", t, i, a);
- }, function (t) {
- invoke("throw", t, i, a);
- }) : e.resolve(h).then(function (t) {
- u.value = t, i(u);
- }, function (t) {
- return invoke("throw", t, i, a);
- });
- }
- a(c.arg);
- }
- var r;
- o(this, "_invoke", {
- value: function value(t, n) {
- function callInvokeWithMethodAndArg() {
- return new e(function (e, r) {
- invoke(t, n, e, r);
- });
- }
- return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();
- }
- });
- }
- function makeInvokeMethod(e, r, n) {
- var o = h;
- return function (i, a) {
- if (o === f) throw Error("Generator is already running");
- if (o === s) {
- if ("throw" === i) throw a;
- return {
- value: t,
- done: !0
- };
- }
- for (n.method = i, n.arg = a;;) {
- var c = n.delegate;
- if (c) {
- var u = maybeInvokeDelegate(c, n);
- if (u) {
- if (u === y) continue;
- return u;
- }
- }
- if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) {
- if (o === h) throw o = s, n.arg;
- n.dispatchException(n.arg);
- } else "return" === n.method && n.abrupt("return", n.arg);
- o = f;
- var p = tryCatch(e, r, n);
- if ("normal" === p.type) {
- if (o = n.done ? s : l, p.arg === y) continue;
- return {
- value: p.arg,
- done: n.done
- };
- }
- "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg);
- }
- };
- }
- function maybeInvokeDelegate(e, r) {
- var n = r.method,
- o = e.iterator[n];
- if (o === t) return r.delegate = null, "throw" === n && e.iterator["return"] && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y;
- var i = tryCatch(o, e.iterator, r.arg);
- if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y;
- var a = i.arg;
- return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y);
- }
- function pushTryEntry(t) {
- var e = {
- tryLoc: t[0]
- };
- 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e);
- }
- function resetTryEntry(t) {
- var e = t.completion || {};
- e.type = "normal", delete e.arg, t.completion = e;
- }
- function Context(t) {
- this.tryEntries = [{
- tryLoc: "root"
- }], t.forEach(pushTryEntry, this), this.reset(!0);
- }
- function values(e) {
- if (e || "" === e) {
- var r = e[a];
- if (r) return r.call(e);
- if ("function" == typeof e.next) return e;
- if (!isNaN(e.length)) {
- var o = -1,
- i = function next() {
- for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next;
- return next.value = t, next.done = !0, next;
- };
- return i.next = i;
- }
- }
- throw new TypeError(_typeof(e) + " is not iterable");
- }
- return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", {
- value: GeneratorFunctionPrototype,
- configurable: !0
- }), o(GeneratorFunctionPrototype, "constructor", {
- value: GeneratorFunction,
- configurable: !0
- }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) {
- var e = "function" == typeof t && t.constructor;
- return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name));
- }, e.mark = function (t) {
- return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t;
- }, e.awrap = function (t) {
- return {
- __await: t
- };
- }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () {
- return this;
- }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) {
- void 0 === i && (i = Promise);
- var a = new AsyncIterator(wrap(t, r, n, o), i);
- return e.isGeneratorFunction(r) ? a : a.next().then(function (t) {
- return t.done ? t.value : a.next();
- });
- }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () {
- return this;
- }), define(g, "toString", function () {
- return "[object Generator]";
- }), e.keys = function (t) {
- var e = Object(t),
- r = [];
- for (var n in e) r.push(n);
- return r.reverse(), function next() {
- for (; r.length;) {
- var t = r.pop();
- if (t in e) return next.value = t, next.done = !1, next;
- }
- return next.done = !0, next;
- };
- }, e.values = values, Context.prototype = {
- constructor: Context,
- reset: function reset(e) {
- if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t);
- },
- stop: function stop() {
- this.done = !0;
- var t = this.tryEntries[0].completion;
- if ("throw" === t.type) throw t.arg;
- return this.rval;
- },
- dispatchException: function dispatchException(e) {
- if (this.done) throw e;
- var r = this;
- function handle(n, o) {
- return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o;
- }
- for (var o = this.tryEntries.length - 1; o >= 0; --o) {
- var i = this.tryEntries[o],
- a = i.completion;
- if ("root" === i.tryLoc) return handle("end");
- if (i.tryLoc <= this.prev) {
- var c = n.call(i, "catchLoc"),
- u = n.call(i, "finallyLoc");
- if (c && u) {
- if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
- if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
- } else if (c) {
- if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
- } else {
- if (!u) throw Error("try statement without catch or finally");
- if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
- }
- }
- }
- },
- abrupt: function abrupt(t, e) {
- for (var r = this.tryEntries.length - 1; r >= 0; --r) {
- var o = this.tryEntries[r];
- if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) {
- var i = o;
- break;
- }
- }
- i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null);
- var a = i ? i.completion : {};
- return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a);
- },
- complete: function complete(t, e) {
- if ("throw" === t.type) throw t.arg;
- return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y;
- },
- finish: function finish(t) {
- for (var e = this.tryEntries.length - 1; e >= 0; --e) {
- var r = this.tryEntries[e];
- if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y;
- }
- },
- "catch": function _catch(t) {
- for (var e = this.tryEntries.length - 1; e >= 0; --e) {
- var r = this.tryEntries[e];
- if (r.tryLoc === t) {
- var n = r.completion;
- if ("throw" === n.type) {
- var o = n.arg;
- resetTryEntry(r);
- }
- return o;
- }
- }
- throw Error("illegal catch attempt");
- },
- delegateYield: function delegateYield(e, r, n) {
- return this.delegate = {
- iterator: values(e),
- resultName: r,
- nextLoc: n
- }, "next" === this.method && (this.arg = t), y;
- }
- }, e;
- }
- module.exports = _regeneratorRuntime, module.exports.__esModule = true, module.exports["default"] = module.exports;
-
- /***/ }),
-
- /***/ 882:
- /***/ ((module) => {
-
- function _typeof(o) {
- "@babel/helpers - typeof";
-
- return module.exports = _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;
- }, module.exports.__esModule = true, module.exports["default"] = module.exports, _typeof(o);
- }
- module.exports = _typeof, module.exports.__esModule = true, module.exports["default"] = module.exports;
-
- /***/ }),
-
- /***/ 501:
- /***/ ((module, __unused_webpack_exports, __webpack_require__) => {
-
- // TODO(Babel 8): Remove this file.
-
- var runtime = __webpack_require__(342)();
- module.exports = runtime;
-
- // Copied from https://github.com/facebook/regenerator/blob/main/packages/runtime/runtime.js#L736=
- try {
- regeneratorRuntime = runtime;
- } catch (accidentalStrictMode) {
- if (typeof globalThis === "object") {
- globalThis.regeneratorRuntime = runtime;
- } else {
- Function("r", "regeneratorRuntime = r")(runtime);
- }
- }
-
-
- /***/ })
-
- /******/ });
- /************************************************************************/
- /******/ // The module cache
- /******/ var __webpack_module_cache__ = {};
- /******/
- /******/ // The require function
- /******/ function __webpack_require__(moduleId) {
- /******/ // Check if module is in cache
- /******/ var cachedModule = __webpack_module_cache__[moduleId];
- /******/ if (cachedModule !== undefined) {
- /******/ return cachedModule.exports;
- /******/ }
- /******/ // Create a new module (and put it into the cache)
- /******/ var module = __webpack_module_cache__[moduleId] = {
- /******/ // no module.id needed
- /******/ // no module.loaded needed
- /******/ exports: {}
- /******/ };
- /******/
- /******/ // Execute the module function
- /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
- /******/
- /******/ // Return the exports of the module
- /******/ return module.exports;
- /******/ }
- /******/
- /************************************************************************/
- /******/ /* webpack/runtime/compat get default export */
- /******/ (() => {
- /******/ // getDefaultExport function for compatibility with non-harmony modules
- /******/ __webpack_require__.n = (module) => {
- /******/ var getter = module && module.__esModule ?
- /******/ () => (module['default']) :
- /******/ () => (module);
- /******/ __webpack_require__.d(getter, { a: getter });
- /******/ return getter;
- /******/ };
- /******/ })();
- /******/
- /******/ /* webpack/runtime/define property getters */
- /******/ (() => {
- /******/ // define getter functions for harmony exports
- /******/ __webpack_require__.d = (exports, definition) => {
- /******/ for(var key in definition) {
- /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
- /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
- /******/ }
- /******/ }
- /******/ };
- /******/ })();
- /******/
- /******/ /* webpack/runtime/hasOwnProperty shorthand */
- /******/ (() => {
- /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
- /******/ })();
- /******/
- /************************************************************************/
- // This entry need to be wrapped in an IIFE because it need to be in strict mode.
- (() => {
- "use strict";
-
- ;// CONCATENATED MODULE: ./node_modules/.pnpm/@babel+runtime@7.25.6/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/.pnpm/@babel+runtime@7.25.6/node_modules/@babel/runtime/helpers/esm/toPrimitive.js
-
- function toPrimitive(t, r) {
- if ("object" != typeof_typeof(t) || !t) return t;
- var e = t[Symbol.toPrimitive];
- if (void 0 !== e) {
- var i = e.call(t, r || "default");
- if ("object" != typeof_typeof(i)) return i;
- throw new TypeError("@@toPrimitive must return a primitive value.");
- }
- return ("string" === r ? String : Number)(t);
- }
-
- ;// CONCATENATED MODULE: ./node_modules/.pnpm/@babel+runtime@7.25.6/node_modules/@babel/runtime/helpers/esm/toPropertyKey.js
-
-
- function toPropertyKey(t) {
- var i = toPrimitive(t, "string");
- return "symbol" == typeof_typeof(i) ? i : i + "";
- }
-
- ;// CONCATENATED MODULE: ./node_modules/.pnpm/@babel+runtime@7.25.6/node_modules/@babel/runtime/helpers/esm/createClass.js
-
- function _defineProperties(e, r) {
- for (var t = 0; t < r.length; t++) {
- var o = r[t];
- o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, toPropertyKey(o.key), o);
- }
- }
- function createClass_createClass(e, r, t) {
- return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", {
- writable: !1
- }), e;
- }
-
- ;// CONCATENATED MODULE: ./node_modules/.pnpm/@babel+runtime@7.25.6/node_modules/@babel/runtime/helpers/esm/classCallCheck.js
- function classCallCheck_classCallCheck(a, n) {
- if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function");
- }
-
- ;// CONCATENATED MODULE: ./node_modules/.pnpm/@babel+runtime@7.25.6/node_modules/@babel/runtime/helpers/esm/defineProperty.js
-
- function defineProperty_defineProperty(e, r, t) {
- return (r = toPropertyKey(r)) in e ? Object.defineProperty(e, r, {
- value: t,
- enumerable: !0,
- configurable: !0,
- writable: !0
- }) : e[r] = t, e;
- }
-
- // EXTERNAL MODULE: ./node_modules/.pnpm/@babel+runtime@7.25.6/node_modules/@babel/runtime/regenerator/index.js
- var regenerator = __webpack_require__(501);
- var regenerator_default = /*#__PURE__*/__webpack_require__.n(regenerator);
- ;// 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("ImgPreview", "_").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 - 35, [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 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 storageData = localStorage.getItem(fullSettingKey);
- var fullSettings = storageData ? JSON.parse(storageData) : {};
- 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.setItem(fullSettingKey, JSON.stringify(fullSettings || {}, null, 2));
- 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 { excludeUrls: [ ],feature:"feature",includedUrls: [ ],name: "name",runType: "0",}
- * @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.getItem(keyOfSETTINGS) || '{}');
- if (!SETTINGS[keyName]) return;
- SETTINGS[keyName].runType = runType || 2;
- localStorage.setItem(keyOfSETTINGS, JSON.stringify(SETTINGS, null, 2));
- }
-
- /**
- * @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<style>\n\t\t\t\t#".concat(_this.scrollbarId, " {\n\t\t\t\t\tposition: sticky;\n\t\t\t\t\twidth: 100%;\n\t\t\t\t\tbox-shadow: 0 15px 0 0 #fff;\n\t\t\t\t\tbottom: 8px;\n\t\t\t\t\tleft: 0;\n\t\t\t\t\theight: 17px;\n\t\t\t\t\toverflow-x: auto;\n\t\t\t\t\toverflow-y: hidden;\n\t\t\t\t\tmargin-top: -17px;\n\t\t\t\t\tz-index: 3;\n\t\t\t\t\t").concat(style, "\n\t\t\t\t}\n\t\t\t</style>\n\t\t\t<div id=\"").concat(_this.thumbId, "\" style=\"height: 1px;\"></div>\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<div data-part=\"thumb\"></div>\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();
- }
- return _createClass(HorizontalScrollBar, [{
- key: "setDefaultStyle",
- value: function setDefaultStyle(scrollbarId) {
- return "\n\t\t<style>\n\t\t\t#".concat(scrollbarId, " {\n\t\t\t\theight: 17px;\n\t\t\t\tbackground-color: #f1f1f1;\n\t\t\t\tposition: relative;\n\t\t\t}\n\t\t\t#").concat(scrollbarId, ">[data-part=\"thumb\"] {\n\t\t\t\theight: 100%;\n\t\t\t\tbackground-color: #c1c1c1;\n\t\t\t\tposition: absolute;\n\t\t\t}\n\t\t\t#").concat(scrollbarId, ">[data-part=\"thumb\"]:active {\n\t\t\t\tbackground-color: #787878;\n\t\t\t}\n\t\t</style>\n\t");
- }
- }]);
- }()));
-
- /** 持久化数据状态 */
- 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;
- }
- return _createClass(PersistentStorage, [{
- key: "write",
- value: function write(val) {
- val = _typeof(val) === 'object' ? JSON.stringify(val, null, 2) : 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);
- }
- }]);
- }()));
-
- /**
- * @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__*/createClass_createClass(function OpenPlus() {
- var _this3 = this;
- var opt = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
- classCallCheck_classCallCheck(this, OpenPlus);
- defineProperty_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_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].getItem(keyOfLevel1));
- } catch (error) {
- isObject = false;
- storage = window[storageName].getItem(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].setItem(keyOfLevel1, JSON.stringify(storage, null, 2));
- } 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, null, 2) : _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);
- }
- return _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);
- }
- }
- }]);
- }()));
- /**移动端 双击 */
- 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;
- });
- }
-
- /**
- * @description 获取dom
- * @export
- * @param {*} element
- * @param {*} selector
- * @param {number} [timeout=80]
- * @param {boolean} [isAlways=true]
- * @returns {*}
- */
- function getElement(_x, _x2) {
- return _getElement.apply(this, arguments);
- }
-
- /**
- * @description 分隔dom分区
- * @param {*} e
- * @param {number} [divideX=3]
- * @param {*} [divideY=divideX]
- * @returns {*} string
- */
- function _getElement() {
- _getElement = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee(element, selector) {
- var timeout,
- isAlways,
- count,
- _args = arguments;
- return _regeneratorRuntime.wrap(function _callee$(_context) {
- while (1) switch (_context.prev = _context.next) {
- case 0:
- timeout = _args.length > 2 && _args[2] !== undefined ? _args[2] : 80;
- isAlways = _args.length > 3 && _args[3] !== undefined ? _args[3] : true;
- count = 0;
- return _context.abrupt("return", new Promise(function (resolve, reject) {
- var timeId = setInterval(function () {
- if (timeout && count++ >= timeout) {
- clearInterval(timeId);
- console.warn('[utils.getElement] Element is not find.' + ' selector: ' + selector);
- // 保持原生逻辑,即未找到时,返回null,便于之后执行埋点,比如错误上报
- return resolve(null);
- }
- var node = element.querySelector(selector);
- if (node) {
- //node 总是返回 或 显示状态条件下,找到后即刻返回
- if (isAlways || node.offsetParent) {
- resolve(node);
- clearInterval(timeId);
- }
- }
- }, 200);
- }));
- case 4:
- case "end":
- return _context.stop();
- }
- }, _callee);
- }));
- return _getElement.apply(this, arguments);
- }
- function divideDom(e) {
- var divideX = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 3;
- var divideY = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : divideX;
- if (!divideX) {
- throw new Error('divideDom 函数 divideX 参数不能为空');
- }
- if (!divideY) {
- divideX = divideY;
- console.warn("divideDom \u51FD\u6570 dom \u5206\u533A \u4E3A ".concat(divideX, "*").concat(divideY));
- }
- var resultStr = "".concat(getIdx(e.target.offsetWidth, divideX, e.offsetX), "-").concat(getIdx(e.target.offsetHeight, divideY, e.offsetY));
- console.log("resultStr => %O ", resultStr);
- return resultStr;
-
- // 获取坐标
- function getIdx(size, divide, offsetPosition) {
- var size_step = Math.ceil(size / divide);
- var posi_idx = Math.floor(offsetPosition / size_step);
- if (offsetPosition % size_step) {
- posi_idx++;
- }
- return posi_idx;
- }
- }
- ;// CONCATENATED MODULE: ./src/tool/previewImg.js
-
-
-
-
- var EMIT_EVENT_TYPE = getBrowserEnv().isPhone ? 'dbltouch' : 'dblclick';
- // const EMIT_EVENT_TYPE = 'dblclick'
- var ImgPreviewer = /*#__PURE__*/createClass_createClass(function ImgPreviewer() {
- var _this = this;
- var _options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
- classCallCheck_classCallCheck(this, ImgPreviewer);
- defineProperty_defineProperty(this, "createGlobalStyle", function () {
- createElement('style', {
- randomType: 'newOne',
- innerHTML: "\n\t\t\t/* \u7F29\u653E */\n\t\t\t body img {\n\n\t\t\t /* \u5149\u6807 \u5448\u73B0 \u653E\u5927\u56FE\u6807 */\n\t\t\t /*\tcursor: zoom-in !important; */\n\n\t\t\t/* \u907F\u514D pointer-events: none; \u60C5\u51B5\u51FA\u73B0 inherit initial auto */\n pointer-events: auto !important;\n\n\t\t\t}\n\n\n\t\t\t"
- });
- });
- /** @描述 状态 */
- defineProperty_defineProperty(this, "state", null);
- defineProperty_defineProperty(this, "shadowRoot", null);
- defineProperty_defineProperty(this, "maskContent", null);
- /** @描述 创建 shadowRoot */
- defineProperty_defineProperty(this, "createShadowRoot", function () {
- var selector = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '#imgPreview';
- selector = selector.replace(/[.#]/g, '');
- var dom = document.querySelector("#".concat(selector));
- if (!dom) {
- dom = createElement('div', {
- addPrefix: false,
- id: selector,
- style: 'width:0;height:0'
- });
- }
- if (!dom.shadowRoot) {
- // 添加在body下,获取 dom.shadowRoot
- dom.attachShadow({
- mode: 'open'
- });
- // dom.shadowRoot.appendChild(maskContent)
- // 创建蒙层容器
- var maskContent = createElement('div', {
- className: 'modal',
- el: dom.shadowRoot
- });
- maskContent.appendChild(_this.createStyle(_this.state));
- }
- return dom.shadowRoot;
- });
- /** @描述 合并选项 */
- defineProperty_defineProperty(this, "mergeOptions", function (options) {
- var opt = {};
- var defaultOptions = {
- contentSelector: 'body',
- selector: 'img',
- showRootSelector: '#img_preview',
- backgroundColor: 'rgba(0,0,0,0)',
- extraStyle: ''
- };
- Object.assign(opt, defaultOptions, options);
- return opt;
- });
- /** @描述 创建shadowbox中的样式 */
- defineProperty_defineProperty(this, "createStyle", function (_ref) {
- var contentSelector = _ref.contentSelector,
- selector = _ref.selector,
- backgroundColor = _ref.backgroundColor,
- extraStyle = _ref.extraStyle;
- return createElement('style', {
- autoInsert: false,
- randomType: 'newOne',
- innerHTML: "".concat(contentSelector, " ").concat(selector, " {\n cursor: zoom-in;\n }\n /* \u56FE\u7247\u9884\u89C8 */\n .modal {\n touch-action: none;\n position: fixed;\n z-index: 10000;\n top: 0;\n left: 0;\n width: 100vw;\n height: 100vh;\n background-color: ").concat(backgroundColor, ";\n user-select: none;\n pointer-events: none;\n\t\t\t--box-shadow-focus:rgb(125 230 221 / 90%);\n }\n .modal>*{\n pointer-events: auto;\n }\n .modal>img {\n position: absolute;\n padding: 0;\n margin: 0;\n box-shadow: var(--box-shadow-focus) 0 0 8px 2px;\n /* border-radius: 10px; */\n /* transition: all var(--delay_time); */\n transform: translateZ(0);\n\t\t\t/* \u900F\u660E\u56FE\u7247 \u886C\u56FE */\n\t\t\tbackground: repeating-conic-gradient(#202020 0, #202020 25%, #303030 0, #303030 50%) 0 0/30px 30px;\n }\n\n img.isPreviewed {\n animation: activeImg 0.5s 4 ease-out forwards;\n transition: all;\n\n }\n\n @keyframes activeImg {\n 0% {\n box-shadow: var(--box-shadow-focus) 0 0 8px 2px;\n }\n 50% {\n box-shadow: rgb(255 0 0 / 70%) 0 0 8px 2px;\n }\n 100% {\n box-shadow: rgb(239 126 4 / 95%) 0 0 8px 2px;\n }\n }\n ").concat(extraStyle, "\n ")
- });
- });
- /** @描述 预览操作 */
- defineProperty_defineProperty(this, "onPreviwerEvent", function () {
- var that = _this;
- var _that$state = that.state,
- contentSelector = _that$state.contentSelector,
- selector = _that$state.selector;
- var eventsProxy = document.querySelector(contentSelector) || window.document.body;
- var operationHandle = function operationHandle(e) {
- var _e$target$imgItemInMo;
- var src = that.getImgSrc(e.target);
- if (!src) return;
- e.preventDefault();
-
- // let previewTargetDom = [...that.shadowRoot.querySelectorAll(selector)].find((item) => that.getImgSrc(item) === src)
- var previewTargetDom = (_e$target$imgItemInMo = e.target.imgItemInModal) === null || _e$target$imgItemInMo === void 0 || (_e$target$imgItemInMo = _e$target$imgItemInMo.state) === null || _e$target$imgItemInMo === void 0 ? void 0 : _e$target$imgItemInMo.cloneEl;
-
- // 第n+1次双击原图预览时
- if (previewTargetDom) {
- //原图的预览图已存在,则激活并最上面显示
- if (!previewTargetDom.classList.contains('isPreviewed')) {
- previewTargetDom.classList.add('isPreviewed');
- // previewTargetDom.remove()
- // that.shadowRoot.querySelector('.modal').appendChild(previewTargetDom)
- that.setTopImg(previewTargetDom);
- } else {
- // previewTargetDom.remove()
-
- e.target.imgItemInModal.ondblclick({
- animation: 'opacity',
- preventDefault: function preventDefault() {
- return null;
- }
- });
- previewTargetDom = null;
- }
- return;
- }
- // 第一次双击原图预览时
- if (!previewTargetDom) {
- // originalEl.style.opacity = 0
- e.target.imgItemInModal = new ImgItemInModal(that.shadowRoot, e.target, src);
- console.log("e.target.imgItemInModal => %O ", e.target.imgItemInModal);
- }
- };
- getBrowserEnv().isPhone ? addDbltouch(eventsProxy, operationHandle) : eventsProxy.addEventListener(EMIT_EVENT_TYPE, operationHandle);
- });
- defineProperty_defineProperty(this, "getImgSrc", function (dom) {
- var _dom$dataset, _window$getComputedSt;
- return (dom === null || dom === void 0 || (_dom$dataset = dom.dataset) === null || _dom$dataset === void 0 ? void 0 : _dom$dataset.src) || (dom === null || dom === void 0 ? void 0 : dom.src) || ((_window$getComputedSt = window.getComputedStyle(dom).backgroundImage.match(/^url\("([^\s]+)"\)$/i)) === null || _window$getComputedSt === void 0 ? void 0 : _window$getComputedSt[1]);
- });
- /** 最顶层的图片 绑定到容器*/
- defineProperty_defineProperty(this, "setTopImg", function (domImg) {
- if (!_this.maskContent) {
- _this.maskContent = _this.shadowRoot.querySelector('.modal');
- }
- if (domImg && _this.maskContent && _this.maskContent.topImg !== domImg) {
- if (_this.maskContent.topImg) {
- _this.maskContent.topImg.style.zIndex = '';
- }
- domImg.style.zIndex = '1';
- _this.maskContent.topImg = domImg;
- }
- });
- this.state = this.mergeOptions(_options);
- this.shadowRoot = this.createShadowRoot();
- this.onPreviwerEvent();
- this.createGlobalStyle();
- return this.shadowRoot;
- });
- var ImgItemInModal = /*#__PURE__*/function () {
- function ImgItemInModal(_shadowRoot, _originalEl, _src) {
- var _this2 = this;
- classCallCheck_classCallCheck(this, ImgItemInModal);
- defineProperty_defineProperty(this, "state", {
- scale: 1,
- offset: {
- left: 0,
- top: 0
- },
- origin: 'center',
- initialData: {
- offset: {},
- origin: 'center',
- scale: 1
- },
- startPoint: {
- x: 0,
- y: 0
- },
- // 记录初始触摸点位
- isTouching: false,
- // 标记是否正在移动
- isMove: false,
- // 正在移动中,与点击做区别
- touches: new Map(),
- // 触摸点数组
- lastDistance: 0,
- lastScale: 1,
- // 记录下最后的缩放值
- scaleOrigin: {
- x: 0,
- y: 0
- },
- // 原图originalEl与预览图cloneEl互相引用
- originalEl: null,
- cloneEl: null
- });
- defineProperty_defineProperty(this, "mergeOptions", function (shadowRoot, originalEl, src) {
- var _window = window,
- winWidth = _window.innerWidth,
- winHeight = _window.innerHeight;
- var offsetWidth = originalEl.offsetWidth,
- offsetHeight = originalEl.offsetHeight;
-
- // Element.getBoundingClientRect() 方法返回元素的大小及其相对于【视口】的位置
- var _originalEl$getBoundi = originalEl.getBoundingClientRect(),
- top = _originalEl$getBoundi.top,
- left = _originalEl$getBoundi.left;
- return {
- shadowRoot: shadowRoot,
- originalEl: originalEl,
- src: src,
- winWidth: winWidth,
- winHeight: winHeight,
- offsetWidth: offsetWidth,
- offsetHeight: offsetHeight,
- top: top,
- left: left,
- maskContent: shadowRoot.querySelector('.modal')
- };
- });
- /** @描述 添加图片 */
- defineProperty_defineProperty(this, "appendImg", function (src, originalEl) {
- // 克隆节点 能从缓存中获取图片,以便节省流量
- var cloneEl = null;
- if (originalEl.tagName === 'IMG') {
- cloneEl = originalEl.cloneNode();
- } else {
- cloneEl = document.createElement('img');
- cloneEl.src = src;
- }
- console.log("\u53CC\u51FB\u7684\u56FE\u7247\u5730\u5740 => %O ", cloneEl.src);
- _this2.state.maskContent.appendChild(cloneEl);
- _this2.setTopImg(cloneEl);
- return cloneEl;
- });
- /** 最顶层的图片 绑定到容器*/
- defineProperty_defineProperty(this, "setTopImg", function (domImg) {
- if (domImg && _this2.state.maskContent && _this2.state.maskContent.topImg !== domImg) {
- if (_this2.state.maskContent.topImg) {
- _this2.state.maskContent.topImg.style.zIndex = '';
- }
- domImg.style.zIndex = '1';
- _this2.state.maskContent.topImg = domImg;
- }
- });
- /** @描述 预览容器modal中的Img元素 添加监听滚轴缩放、移动、双击事件 */
- defineProperty_defineProperty(this, "onEventsController", function (cloneEl) {
- var eventType = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'addEventListener';
- var events = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [EMIT_EVENT_TYPE, 'mousewheel', 'pointerdown', 'pointerup', 'pointermove', 'pointercancel', 'mouseleave'];
- console.log("onEventsController \u7684 eventType=> %O ", eventType);
- var that = _this2;
- events.forEach(function (item) {
- if (item === 'mousewheel') {
- if (EMIT_EVENT_TYPE === 'dbltouch') {
- addDbltouch(cloneEl, that.ondbltouch);
- } else {
- cloneEl[eventType]('mousewheel', that["on".concat(item)], {
- passive: false
- });
- }
- return;
- }
- cloneEl[eventType](item, that["on".concat(item)]);
- });
- });
- /** @描述 双击事件 */
- defineProperty_defineProperty(this, "ondblclick", function (e) {
- _this2.ondbltouch(e);
- return;
- e.preventDefault();
- var that = _this2;
- var state = that.state;
- console.log("\u5F53\u524D\u9884\u89C8\u56FE\u7247\u7684\u72B6\u6001\u53CA\u5F15\u7528\u5173\u7CFBstate => %O ", state);
- if (state.isMove) {
- state.isMove = false;
- } else {
- // const animationTime = this.getTimeOfClearImgAnimation(state)
- var animationTime = 0.4;
- var originalElPositionState = state.originalEl.getBoundingClientRect();
- that.changeStyle(state.cloneEl, ["transform: translate(0,0)", "transition: all ".concat(animationTime, "s ease-out"), "left: ".concat(originalElPositionState.left, "px"), "top: ".concat(originalElPositionState.top, "px"), "width: ".concat(originalElPositionState.width, "px")]);
- // state.cloneEl.removeEventListener('dblclick', that.ondblclick)
-
- // this.onEventsController(state.cloneEl, 'removeEventListener')
- setTimeout(function () {
- // state.maskContent.removeChild(state.cloneEl)
- console.log('开始执行清除预览图片');
- // 先清除原图对预览图的引用
- state.cloneEl.remove();
- state.cloneEl = null;
- state.originalEl.imgItemInModal = null;
- }, animationTime * 1000 + 100);
- }
- });
- /** @描述 双触摸事件 */
- defineProperty_defineProperty(this, "ondbltouch", function (e) {
- e.preventDefault();
- var that = _this2;
- var state = that.state;
- console.log("\u5F53\u524D\u9884\u89C8\u56FE\u7247\u7684\u72B6\u6001\u53CA\u5F15\u7528\u5173\u7CFBstate => %O ", state);
- if (state.isMove) {
- state.isMove = false;
- } else {
- var animationTime = 0.4;
- if (e.animation == 'opacity') {
- // 点击原图清除时,透明后清除,不干扰用户浏览内容
- // const animationTime = this.getTimeOfClearImgAnimation(state)
- var originalElPositionState = state.originalEl.getBoundingClientRect();
- that.changeStyle(state.cloneEl, ["opacity: 0", "transition: all ".concat(animationTime, "s ease-out")]);
- } else {
- // 点击预览图清除时,移动后清除,便于定位预览图的原图位置
- // const animationTime = this.getTimeOfClearImgAnimation(state)
- var _originalElPositionState = state.originalEl.getBoundingClientRect();
- that.changeStyle(state.cloneEl, ["transform: translate(0,0)", "transition: all ".concat(animationTime, "s ease-out"), "left: ".concat(_originalElPositionState.left, "px"), "top: ".concat(_originalElPositionState.top, "px"), "width: ".concat(_originalElPositionState.width, "px")]);
- }
-
- // state.cloneEl.removeEventListener('dblclick', that.ondblclick)
- _this2.onEventsController(state.cloneEl, 'removeEventListener');
- setTimeout(function () {
- // state.maskContent.removeChild(state.cloneEl)
- console.log('开始执行清除预览图片');
- // 先清除原图对预览图的引用
- state.cloneEl.remove();
- state.cloneEl = null;
- state.originalEl.imgItemInModal = null;
- }, animationTime * 1000 + 100);
- }
- });
- /** 清除预览图片动作时长 */
- defineProperty_defineProperty(this, "getTimeOfClearImgAnimation", function (state) {
- var cloneElPositionState = state.cloneEl.getBoundingClientRect();
- var originalElPositionState = state.originalEl.getBoundingClientRect();
- var maxOffsetVal = Math.max(Math.abs(originalElPositionState.left - cloneElPositionState.left), Math.abs(originalElPositionState.top - cloneElPositionState.top));
- var animationTime = 0.1 * maxOffsetVal / 400 + 0.2;
- console.log('清除预览图片的距离及动作时长: ', maxOffsetVal + 'px', animationTime + 's');
- return animationTime;
- });
- /** @描述 指针按下事件*/
- defineProperty_defineProperty(this, "onpointerdown", function (e) {
- e.preventDefault();
- var that = _this2;
- var state = that.state;
- state.touches.set(e.pointerId, e);
- // TODO: 点击存入触摸点
- state.isTouching = true;
- state.startPoint = {
- x: e.clientX,
- y: e.clientY
- };
- if (state.touches.size === 2) {
- // TODO: 判断双指触摸,并立即记录初始数据
- state.lastDistance = that.getDistance();
- state.lastScale = state.scale;
- }
- _this2.setTopImg(e.target);
- });
- /** @描述 滚轮缩放 */
- defineProperty_defineProperty(this, "onmousewheel", function (e) {
- e.preventDefault();
- if (!e.deltaY) return;
- var that = _this2;
- var state = that.state;
- state.origin = "".concat(e.offsetX, "px ").concat(e.offsetY, "px");
-
- // 缩放执行
- if (e.deltaY < 0) {
- // 放大
- state.scale += 0.18;
- } else if (e.deltaY > 0) {
- state.scale >= 0.28 && (state.scale -= 0.18);
- // 缩小
- }
- if (state.scale < state.initialData.scale) {
- that.reduction();
- }
- state.offset = that.getOffsetPageCenter(e.offsetX, e.offsetY);
- that.changeStyle(state.cloneEl, ['transition: all .15s', "transform-origin: ".concat(state.origin), "transform: translate(".concat(state.offset.left + 'px', ", ").concat(state.offset.top + 'px', ") scale(").concat(state.scale, ")")]);
- _this2.setTopImg(e.target);
- });
- /** @描述 获取中心改变的偏差 */
- defineProperty_defineProperty(this, "getOffsetPageCenter", function () {
- var x = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
- var y = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
- var state = _this2.state;
- var touchArr = Array.from(state.touches);
- if (touchArr.length === 2) {
- var start = touchArr[0][1];
- var end = touchArr[1][1];
- x = (start.offsetX + end.offsetX) / 2;
- y = (start.offsetY + end.offsetY) / 2;
- }
- state.origin = "".concat(x, "px ").concat(y, "px");
- var offsetLeft = (state.scale - 1) * (x - state.scaleOrigin.x) + state.offset.left;
- var offsetTop = (state.scale - 1) * (y - state.scaleOrigin.y) + state.offset.top;
- state.scaleOrigin = {
- x: x,
- y: y
- };
- return {
- left: offsetLeft,
- top: offsetTop
- };
- });
- /** @描述 获取距离*/
- defineProperty_defineProperty(this, "getDistance", function () {
- var touchArr = Array.from(_this2.state.touches);
- if (touchArr.length < 2) {
- return 0;
- }
- var start = touchArr[0][1];
- var end = touchArr[1][1];
- return Math.hypot(end.x - start.x, end.y - start.y);
- });
- /** @描述 修改样式,减少回流重绘*/
- defineProperty_defineProperty(this, "changeStyle", function (el, arr, isResetAllStyle) {
- var original = el.style.cssText.split(';');
- original.pop();
- if (isResetAllStyle) {
- el.className = '';
- el.style.cssText = arr.join(';') + ';';
- } else {
- el.style.cssText = original.concat(arr).join(';') + ';';
- }
- });
- /** @描述 还原记录,用于边界处理 */
- defineProperty_defineProperty(this, "reduction", function () {
- var that = _this2;
- var state = that.state;
- that.timer && clearTimeout(that.timer);
- that.timer = setTimeout(function () {
- that.changeStyle(state.cloneEl, ["transform: translate(".concat(state.offset.left + 'px', ", ").concat(state.offset.top + 'px', ") scale(").concat(state.scale, ")"), "transform-origin: ".concat(state.origin)]);
- }, 300);
- });
- /** @描述 松开指针 事件 */
- defineProperty_defineProperty(this, "onpointerup", function (e) {
- e.preventDefault();
- var that = _this2;
- var state = that.state;
- state.touches["delete"](e.pointerId);
- // TODO: 抬起移除触摸点
- if (state.touches.size <= 0) {
- state.isTouching = false;
- } else {
- var touchArr = Array.from(state.touches);
- // 更新点位
- state.startPoint = {
- x: touchArr[0][1].clientX,
- y: touchArr[0][1].clientY
- };
- }
- setTimeout(function () {
- state.isMove = false;
- }, 300);
- });
- /** @描述 指针移动事件 */
- defineProperty_defineProperty(this, "onpointermove", function (e) {
- e.preventDefault();
- var that = _this2;
- var state = that.state;
- if (state.isTouching) {
- state.isMove = true;
- if (state.touches.size < 2) {
- // 单指滑动
- state.offset = {
- left: state.offset.left + (e.clientX - state.startPoint.x),
- top: state.offset.top + (e.clientY - state.startPoint.y)
- };
- that.changeStyle(state.cloneEl, ['transition: all 0s', "transform: translate(".concat(state.offset.left + 'px', ", ").concat(state.offset.top + 'px', ") scale(").concat(state.scale, ")"), "transform-origin: ".concat(origin)]);
- // 更新点位
- state.startPoint = {
- x: e.clientX,
- y: e.clientY
- };
- } else {
- // 双指缩放
- state.touches.set(e.pointerId, e);
- var ratio = that.getDistance() / state.lastDistance;
- state.scale = ratio * state.lastScale;
- state.offset = that.getOffsetPageCenter();
- if (state.scale < state.initialData.scale) {
- that.reduction();
- }
- that.changeStyle(state.cloneEl, ['transition: all 0s', "transform: translate(".concat(state.offset.left + 'px', ", ").concat(state.offset.top + 'px', ") scale(").concat(state.scale, ")"), "transform-origin: ".concat(state.origin)]);
- }
- }
- });
- /** @描述 取消指针事件 */
- defineProperty_defineProperty(this, "onpointercancel", function (e) {
- e.preventDefault();
- _this2.state.touches.clear();
- // 可能存在特定事件导致中断,真机操作时 pointerup 在某些边界情况下不会生效,所以需要清空
- });
- /** 鼠标离开图片时,移动操作结束 */
- defineProperty_defineProperty(this, "onmouseleave", function (e) {
- _this2.state.isMove = false;
- _this2.state.isTouching = false;
- });
- /** @描述 移动图片到屏幕中心位置 */
- defineProperty_defineProperty(this, "fixPosition", function (cloneEl) {
- var that = _this2;
- var state = that.state;
-
- /** @描述 原图片 中心点 */
- var originalCenterPoint = {
- x: state.offsetWidth / 2 + state.left,
- y: state.offsetHeight / 2 + state.top
- };
-
- /** @描述 页面 中心点 */
- var winCenterPoint = {
- x: state.winWidth / 2,
- y: state.winHeight / 2
- };
-
- /** @描述 新建图片的定位点:通过原图片中心点到页面中心点的 偏移量*/
- var offsetDistance = {
- left: winCenterPoint.x - originalCenterPoint.x + state.left,
- top: winCenterPoint.y - originalCenterPoint.y + state.top
- };
-
- /** @描述 放大后的 */
- var scaleNum = _this2.adaptScale();
- var diffs = {
- left: (scaleNum - 1) * state.offsetWidth / 2,
- top: (scaleNum - 1) * state.offsetHeight / 2
- };
- _this2.changeStyle(cloneEl, ["left: ".concat(state.left, "px"), "top: ".concat(state.top, "px"), 'transition: all 0.3s', "width: ".concat(state.offsetWidth * scaleNum + 'px'), "height:auto", "transform: translate(".concat(offsetDistance.left - state.left - diffs.left, "px, ").concat(offsetDistance.top - state.top - diffs.top, "px)")], true);
-
- /** @描述 消除偏差:让图片相对于window 0 0定位,通过translate设置中心点重合*/
- setTimeout(function () {
- that.changeStyle(cloneEl, ['transition: all 0s', "left: 0", "top: 0", "transform: translate(".concat(offsetDistance.left - diffs.left, "px, ").concat(offsetDistance.top - diffs.top, "px)")]);
- that.state.offset = {
- left: offsetDistance.left - diffs.left,
- top: offsetDistance.top - diffs.top
- };
- // 记录值
- that.record();
- }, 300);
- });
- /** @描述 计算自适应屏幕的缩放 */
- defineProperty_defineProperty(this, "adaptScale", function () {
- var _this2$state = _this2.state,
- winWidth = _this2$state.winWidth,
- winHeight = _this2$state.winHeight,
- originalEl = _this2$state.originalEl;
- var w = originalEl.offsetWidth,
- h = originalEl.offsetHeight;
- var scale = (winWidth - 60) / w;
- if (h * scale > winHeight - 60) {
- scale = (winHeight - 60) / h;
- }
- return scale;
- });
- this.state = Object.assign({}, this.state, this.mergeOptions(_shadowRoot, _originalEl, _src));
- var _cloneEl = this.appendImg(_src, _originalEl);
- this.state.cloneEl = _cloneEl;
- this.fixPosition(_cloneEl);
- this.onEventsController(_cloneEl);
- // return this
- }
- return createClass_createClass(ImgItemInModal, [{
- key: "record",
- value: /** @描述 记录初始化数据 */
- function record() {
- var state = this.state;
- state.initialData = Object.assign({}, {
- offset: state.offset,
- origin: state.origin,
- scale: state.scale
- });
- }
- }]);
- }();
- function run() {
- try {
- if (codeIsNotExcutable('previewImg', {
- name: '图文对照阅读',
- feature: '图片预览,固定图片,便于图文对照阅读',
- includedUrls: []
- }).notExcutable) return;
- var shadowRoot = new ImgPreviewer({
- backgroundColor: 'transparent'
- });
- } catch (error) {
- console.error(error);
- }
- }
- ;// CONCATENATED MODULE: ./src/tool/addBackgroundImg.js
-
- /**
- * @description 添加背景色
- */
- function addBackgroundImg_run() {
- try {
- if (codeIsNotExcutable('addBackgroundImg', {
- name: '添加背景图片',
- feature: '使用浏览器查看在线图片或本地图片时,增加页面背景图,以便清晰显示当前图片轮廓',
- includedUrls: []
- }).notExcutable) return;
- addBackgroundImg();
- } catch (error) {
- console.error(error);
- }
- }
-
- /** @描述 添加背景色*/
- function addBackgroundImg() {
- var ua = navigator.userAgent.toLowerCase();
- var doc = document.body || document.documentElement;
- var isQQBrowser = ua.indexOf('qqbrowser/') > -1;
- if (document.contentType.startsWith('image/')) {
- if (isQQBrowser && doc.tagName !== 'svg') {
- setTimeout(function () {
- loaded();
- }, 666);
- } else {
- loaded();
- }
- }
- }
- function loaded() {
- var doc = document.body || document.documentElement;
- var win = window;
- // var bgImage = ``
-
- var bgCSS = "repeating-conic-gradient(#202020 0, #202020 25%, #303030 0, #303030 50%) 0 0/30px 30px !important";
-
- /* .bgImage{
- background: #202020;
- background-image: linear-gradient(45deg, #303030 25%, transparent 0), linear-gradient(45deg, transparent 75%, #303030 0), linear-gradient(45deg, #303030 25%, transparent 0), linear-gradient(45deg, transparent 75%, #303030 0);
- background-position: 0 0, 15px 15px, 15px 15px, 30px 30px;
- background-size: 30px 30px;
- } */
-
- var docTagName = function (tag) {
- var tagName = tag && tag.tagName.toLowerCase();
- if (tagName) {
- if (tagName == 'svg') {
- return tagName;
- }
- if (tagName == 'body' && tag.children && tag.children.length) {
- tagName = tag.children[0].tagName.toLowerCase();
- if (tagName == 'img') {
- return tagName;
- } else {
- tagName = document.querySelector('img');
- return tagName && tagName.tagName && tagName.tagName.toLowerCase();
- }
- }
- }
- }(doc);
- var isViewerMode = docTagName == 'svg' || docTagName == 'img';
- var imgOutlineCss = "img:hover{outline: 0.5px dotted rgb(254 254 254 / 20%);}";
- if (isViewerMode) {
- if (document.head) {
- var styleText = [];
- if (isQQBrowserPS()) {
- styleText.push("body{box-sizing: border-box;background-attachment: fixed !important;background-repeat: repeat !important;}");
- // styleText.push(`body{background: url(${bgImage}) !important;}`)
- styleText.push("body{background: ".concat(bgCSS, ";}"));
- } else {
- styleText.push("img{position: static !important;background-color: rgba(0, 0, 0, 0) !important;}".concat(imgOutlineCss));
- }
- if (document.body.innerText) {
- createElement('style', {
- randomType: 'newOne',
- el: 'head',
- type: 'text/css',
- innerHTML: styleText.join('')
- }, win);
- } else {
- // 本地图片文件
- createElement('style', {
- randomType: 'newOne',
- el: 'head',
- type: 'text/css',
- innerHTML: "body{background: ".concat(bgCSS, ";}img{background-color: rgba(0, 0, 0, 0) !important;}").concat(imgOutlineCss)
- }, win);
- }
- }
- if (isQQBrowserPS()) {
- doc.style.position = 'static';
- doc.style.top = 'auto';
- doc.style.left = 'auto';
- doc.style.transform = 'none';
- } else {
- // doc.style.backgroundImage = `url(${bgImage})`
- doc.style.background = bgCSS;
- doc.style.backgroundAttachment = 'fixed';
- doc.style.boxSizing = 'border-box';
- doc.style.outline = '1px dashed #696767';
- if (docTagName == 'svg') {
- doc.style.position = 'absolute';
- doc.style.top = '50%';
- doc.style.left = '50%';
- doc.style.transform = 'translate(-50%, -50%)';
- doc.style.margin = '10px';
- doc.style.width = 'auto';
- doc.style.height = 'auto';
- doc.style.maxWidth = '100%';
- doc.style.maxHeight = '100%';
- }
- }
- }
- function isQQBrowserPS() {
- return document && document.body && document.body.classList.contains('qb-picture-ps');
- }
- }
- ;// CONCATENATED MODULE: ./node_modules/.pnpm/@babel+runtime@7.25.6/node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js
- function _arrayLikeToArray(r, a) {
- (null == a || a > r.length) && (a = r.length);
- for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
- return n;
- }
-
- ;// CONCATENATED MODULE: ./node_modules/.pnpm/@babel+runtime@7.25.6/node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js
-
- function _arrayWithoutHoles(r) {
- if (Array.isArray(r)) return _arrayLikeToArray(r);
- }
-
- ;// CONCATENATED MODULE: ./node_modules/.pnpm/@babel+runtime@7.25.6/node_modules/@babel/runtime/helpers/esm/iterableToArray.js
- function _iterableToArray(r) {
- if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r);
- }
-
- ;// CONCATENATED MODULE: ./node_modules/.pnpm/@babel+runtime@7.25.6/node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js
-
- function _unsupportedIterableToArray(r, a) {
- if (r) {
- if ("string" == typeof r) return _arrayLikeToArray(r, a);
- var t = {}.toString.call(r).slice(8, -1);
- return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0;
- }
- }
-
- ;// CONCATENATED MODULE: ./node_modules/.pnpm/@babel+runtime@7.25.6/node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js
- function _nonIterableSpread() {
- throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
- }
-
- ;// CONCATENATED MODULE: ./node_modules/.pnpm/@babel+runtime@7.25.6/node_modules/@babel/runtime/helpers/esm/toConsumableArray.js
-
-
-
-
- function _toConsumableArray(r) {
- return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread();
- }
-
- ;// CONCATENATED MODULE: ./node_modules/.pnpm/@babel+runtime@7.25.6/node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js
- function asyncGeneratorStep(n, t, e, r, o, a, c) {
- try {
- var i = n[a](c),
- u = i.value;
- } catch (n) {
- return void e(n);
- }
- i.done ? t(u) : Promise.resolve(u).then(r, o);
- }
- function asyncToGenerator_asyncToGenerator(n) {
- return function () {
- var t = this,
- e = arguments;
- return new Promise(function (r, o) {
- var a = n.apply(t, e);
- function _next(n) {
- asyncGeneratorStep(a, r, o, _next, _throw, "next", n);
- }
- function _throw(n) {
- asyncGeneratorStep(a, r, o, _next, _throw, "throw", n);
- }
- _next(void 0);
- });
- };
- }
-
- ;// CONCATENATED MODULE: ./src/tool/openUrlInText.js
-
-
-
-
- /**
- * @description 含有链接的文本,点击时跳转相应链接
- * @export
- */
- function openUrlInText_run() {
- try {
- if (codeIsNotExcutable('openUrlInText', {
- name: '单击打开文本中链接',
- feature: '点击链接文本时,跳转相应链接,便于查看链接地址的内容',
- includedUrls: []
- }).notExcutable) return;
- var openPlus = new OpenPlus();
- window.addEventListener('click', /*#__PURE__*/function () {
- var _ref = asyncToGenerator_asyncToGenerator(/*#__PURE__*/regenerator_default().mark(function _callee(e) {
- var _innerTextsOfAllText$;
- var dom, innerTextsOfAllText, url;
- return regenerator_default().wrap(function _callee$(_context) {
- while (1) switch (_context.prev = _context.next) {
- case 0:
- dom = e.target; // 非左击
- if (!(e.button !== 0)) {
- _context.next = 3;
- break;
- }
- return _context.abrupt("return");
- case 3:
- if (!(dom.childElementCount && !_toConsumableArray(dom.childNodes).find(function (item) {
- var _item$textContent$mat, _item$textContent;
- return item.nodeName === '#text' && ((_item$textContent$mat = (_item$textContent = item.textContent).match) === null || _item$textContent$mat === void 0 ? void 0 : _item$textContent$mat.call(_item$textContent, /https?:\/\/[\S]{4,}/));
- }))) {
- _context.next = 5;
- break;
- }
- return _context.abrupt("return");
- case 5:
- if (!(dom.tagName === 'A' && dom !== null && dom !== void 0 && dom.href)) {
- _context.next = 7;
- break;
- }
- return _context.abrupt("return");
- case 7:
- if (!isContentEditableOfDOM()) {
- _context.next = 9;
- break;
- }
- return _context.abrupt("return");
- case 9:
- if (!window.getSelection().toString()) {
- _context.next = 11;
- break;
- }
- return _context.abrupt("return");
- case 11:
- innerTextsOfAllText = dom.innerText;
- url = innerTextsOfAllText === null || innerTextsOfAllText === void 0 || (_innerTextsOfAllText$ = innerTextsOfAllText.match) === null || _innerTextsOfAllText$ === void 0 ? void 0 : _innerTextsOfAllText$.call(innerTextsOfAllText, /https?:\/\/[\S]{4,}/);
- if (url) {
- /* openPlus.openPre(
- async () => {
- await awaitTime(100)
- createLinkStyle(url[0], dom)
- },
- url[0],
- url[0]
- ) */
- openPlus.open(url[0], url[0]);
- }
- case 14:
- case "end":
- return _context.stop();
- }
- }, _callee);
- }));
- return function (_x) {
- return _ref.apply(this, arguments);
- };
- }(), {
- capture: true //利用捕获阶段,解决【阻止冒泡】阻断事件传播
- });
- /* function createLinkStyle(url, element) {
- if (!url) return
- element.innerHTML = element.innerHTML.trim().split(url).join(`<a href='${url}' target='${url}'> ${url} </a>`)
- } */
- } catch (error) {
- console.error(error);
- }
- }
-
- /*
- window.open打开已在的窗口(不同源)时只激活不刷新
-
-
- 备注:
-
-
-
- */
- ;// CONCATENATED MODULE: ./src/tool/copySelectedText.js
-
-
- /**
- * @description 复制所选文字:鼠标选中文字后,0.5秒内松开左键,自动复制到剪贴板;超过 0.5秒后松开,不再进行复制;一键复制代码块:鼠标悬浮代码块后,点击显示的红色边框,复制到剪贴板
- * @export
- */
- function copySelectedText_run() {
- try {
- var onEmitCopyHandle = function onEmitCopyHandle(e) {
- if (isContentEditableOfDOM()) return;
- var dom = e.target;
- var selectedText = window.getSelection().toString(); // window.getSelection().toString() 双击空白处 会选中 \n
-
- // || dom.tagName === 'BLOCKQUOTE'
- // https://mp.weixin.qq.com/s/1iBEjoZeA7bUmpAA1KEYhA
-
- /*
- https://blog.csdn.net/Charissa2017/article/details/103863588
- offsetWidth 盒子自身占据的空间 ,包含 边框
- clientWidth 盒子自身容器拥有的空间 ,包含 padding,但 不包含边框
- */
- //
-
- if (dom.tagName === 'PRE' && e.target.offsetWidth >= e.offsetX && e.target.clientWidth <= e.offsetX) {
- var getCodesInnerText = function getCodesInnerText(dom, selector) {
- var nodeList = dom.querySelectorAll('code');
- if (nodeList.length) {
- return _toConsumableArray(nodeList).reduce(function (pre, cur) {
- return pre + cur.innerText + '\n';
- }, '');
- }
- return '';
- };
- // dom.querySelector('code')?.innerText csdn 序号在pre标签里
-
- // const willCopyText = selectedText || dom.querySelector('code')?.innerText || dom.innerText
- // const willCopyText = selectedText || dom.innerText
-
- var willCopyText = selectedText || getCodesInnerText(dom, 'code') || dom.innerText;
- copyTextAndTip(e, willCopyText, selectedText);
- } else if (selectedText.replace(/\s/g, '')) {
- copyTextAndTip(e, '', selectedText);
- }
- }; // document.documentElement.addEventListener('click', onEmitCopyHandle, {
- // capture: true, //利用捕获阶段,解决【阻止冒泡】阻断事件传播
- // })
- var copyTextAndTip = function copyTextAndTip(e, willCopyText, selectedText) {
- setTimeout(function () {
- createElementTip({
- e: e,
- content: selectedText ? '文字_复制成功' : '代码块_复制成功'
- });
- doCopy((willCopyText || selectedText).trim());
- }, 500);
- };
- // const filename = 'copySelectedText'
- var filename = "copySelectedText";
- if (codeIsNotExcutable(filename, {
- name: '复制所选文本',
- feature: '1、复制所选文字:鼠标选中文字后,0.5秒 后松开左键后,自动复制到剪贴板,超过 0.5秒松开,不进行复制;2、一键复制代码块:鼠标悬浮代码块后,点击显示的红色边框,复制到剪贴板',
- includedUrls: []
- }).notExcutable) return;
- createElement('style', {
- el: 'head',
- id: 'a_click_target',
- randomType: 'newOne',
- textContent: "\n\t\t/* \u5141\u8BB8\u590D\u5236 */\n\t\t* {\n\t\t\tuser-select: text !important;\n\t\t}\n\n\t\t/* fix https://developer.mozilla.org/zh-CN/play */\n\t\tpre, code{\n\t\t\tword-break: break-all;\n\t\t}\n\n\t\t/* \u4E00\u952E\u590D\u5236\u4EE3\u7801\uFF1A\u9F20\u6807\u60AC\u6D6E\u4EE3\u7801\uFF0C\u70B9\u51FB\u7EA2\u8272\u8FB9\u6846 */\n\t\t:not(blockquote, pre) > pre {\n\t\t\t/* border-left: 8px solid #6d6b6b45 !important; */\n\t\t\t/* border-left: 8px solid transparent !important; */\n\t\t\tborder-radius: 4px !important;\n\t\t\toverflow-x: auto !important;\n\t\t\twhite-space: pre-wrap !important;\n\t\t\tcursor: pointer;\n\t\t}\n\t\t:not(blockquote, pre) > pre:hover {\n\t\t\t/* border-left-color: #6709099c !important; */\n\t\t\tborder-right: 8px solid #6709099c !important;\n\t\t\tmargin-right: -8px;\n\t\t\tposition: relative;\n\t\t}\n\n\t\t/* :not(blockquote, pre) > pre:hover:after {\n\t\t\tcontent: '\u4E00\u952E\u590D\u5236';\n\t\t\tdisplay: inline-block;\n\t\t\twidth: 10px;\n\t\t\ttransform: translateX(-4px);\n\t\t\tfont-size: 10px;\n\t\t\tposition: absolute;\n\t\t\ttop: 0;\n\t\t\tright: -4px;\n\t\t\tcolor: #fff;\n\t\t\tline-height: 14px;\n\t\t\tbackground: #a26969;\n\t\t\tpadding: 0 0 6px 4px;\n\t\t\tborder-radius: 0 0 0 16px;\n\t\t} */\n\n\t\t/* \u6CE8\u91CA\u6587\u672C\u8FC7\u957F\u65F6\uFF0C\u6362\u884C */\n\t\t:not(blockquote, pre) > pre > * {\n\t\t\tborder-radius: 0 !important;\n\t\t\twhite-space: pre-wrap !important;\n\t\t\tcursor: auto;\n\t\t}\n\n\t\t:not(blockquote, pre) > pre code {\n\t\t\tdisplay: block !important;\n\t\t}\n"
- });
- var createElementTip = createElementTipFn();
- var pre_done_time = 0;
- var is_mousedown = false;
- var is_mousemove = false; // 避免双击时,选中复制
- document.documentElement.addEventListener('mousedown', function () {
- is_mousedown = true;
- pre_done_time = Date.now();
- }, {
- capture: true //利用捕获阶段,解决【阻止冒泡】阻断事件传播
- });
- document.documentElement.addEventListener('mousemove', function () {
- if (is_mousedown) {
- pre_done_time = Date.now();
- is_mousemove = true;
- }
- }, {
- capture: true //利用捕获阶段,解决【阻止冒泡】阻断事件传播
- });
- document.documentElement.addEventListener('mouseup', function (e) {
- if (is_mousedown && is_mousemove && Date.now() - pre_done_time < 500) {
- onEmitCopyHandle(e);
- }
- is_mousedown = false;
- is_mousemove = false;
- }, {
- capture: true //利用捕获阶段,解决【阻止冒泡】阻断事件传播
- });
- } catch (error) {
- console.error(error);
- }
- }
- ;// CONCATENATED MODULE: ./src/tool/csdn.js
-
- function csdn_run() {
- try {
- if (codeIsNotExcutable('csdn', {
- name: 'csdn登录',
- feature: 'CSDN:仅在主动触发登录时,显示登录弹层,以便减少不必要的登录',
- includedUrls: ['csdn.net']
- }).notExcutable) return;
- createElement('style', {
- el: 'head',
- id: 'csdn-ui',
- textContent: "\n /* csdn \u4EE3\u7801\u5185\u5BB9\u5168\u5C55\u793A */\n .hide-preCode-box{\n padding-top:0px !important;\n }\n\n /* \u9690\u85CF\u3010\u767B\u5F55\u540E\u590D\u5236\u3011\u6587\u6848*/\n .hljs-button.signin{\n opacity:0;\n }\n\n /* csdn\u767B\u5F55\u5F39\u5C42\u79FB\u81F3\u5DE6\u4E0B\u89D2\n .passport-login-container {\n top:calc(100vh - 485px) !important;\n width:410px !important;\n height: 520px !important;\n border-radius: 8px !important;\n box-shadow: -5px 5px 10px 5px #979393 !important;\n transform: scale(0.8) !important;\n left: -24px;\n }\n */\n "
- });
- createElement('style', {
- el: 'head',
- addPrefix: '',
- id: 'csdn-ui-login',
- randomType: 'single',
- textContent: "\n /* \u9690\u85CF\u767B\u5F55\u5F39\u5C42 */\n .passport-login-container{\n display:none;\n }\n .passport-login-mark {\n display:none !important;\n }\n "
- });
- document.addEventListener('click', function (e) {
- var _target$className, _target$className$inc;
- var target = e.target;
- if ((_target$className = target.className) !== null && _target$className !== void 0 && (_target$className$inc = _target$className.includes) !== null && _target$className$inc !== void 0 && _target$className$inc.call(_target$className, 'toolbar-btn-loginfun')) {
- var _document$querySelect;
- (_document$querySelect = document.querySelector('#csdn-ui-login')) === null || _document$querySelect === void 0 || _document$querySelect.remove();
- }
- });
- } catch (error) {
- console.error(error);
- }
- }
- ;// CONCATENATED MODULE: ./src/tool/calibreUI.js
-
- // 解压后的epub电子书 浏览器预览
- function calibreUI_run() {
- try {
- if (location.href.toLocaleLowerCase().includes('/oebps/text/')) {
- modifyUI();
- }
- } catch (error) {
- console.error(error);
- }
- }
- function modifyUI() {
- createElement('style', {
- id: 'calibreUI',
- innerHTML: "\n\t\t\tbody {\n\t\t\t\tmax-width:700px;\n\t\t\t}\n\t\t\t"
- }, window);
- }
- ;// CONCATENATED MODULE: ./src/ImgPreview.js
-
- ImgPreview_run();
- function ImgPreview_run() {
- run();
- addBackgroundImg_run();
- openUrlInText_run();
- copySelectedText_run();
- csdn_run();
- calibreUI_run();
- }
- })();
-
- /******/ })()
- ;