您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Подсветка служебных страниц ВКонтакте.
当前为
// ==UserScript== // @name GosVon Marking for VK // @namespace vk-metabot-user-js // @description Подсветка служебных страниц ВКонтакте. // @version 3.06 // @homepageURL https://vk.com/club187686148 // @match https://*.vk.com/* // @match *://web.archive.org/*://*vk.com/* // @exclude *://queuev4.vk.com/* // @connect gosvon.net // @connect api.gosvon.net // @connect gosvon.github.io // @connect *.vercel.app // @connect *.netlify.app // @update https://raw.githubusercontent.com/gosvon/gosvon/user-script/vk-metabot.user.js // @grant GM_xmlhttpRequest // @grant GM.xmlHttpRequest // @grant GM_setValue // @grant GM_getValue // @grant GM_deleteValue // @run-at document-end // ==/UserScript== (() => { var __webpack_modules__ = { 397: (module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.d(__webpack_exports__, { Z: () => __WEBPACK_DEFAULT_EXPORT__ }); var _node_modules_pnpm_css_loader_6_8_1_webpack_5_88_2_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(885); var _node_modules_pnpm_css_loader_6_8_1_webpack_5_88_2_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default = __webpack_require__.n(_node_modules_pnpm_css_loader_6_8_1_webpack_5_88_2_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__); var _node_modules_pnpm_css_loader_6_8_1_webpack_5_88_2_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(118); var _node_modules_pnpm_css_loader_6_8_1_webpack_5_88_2_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = __webpack_require__.n(_node_modules_pnpm_css_loader_6_8_1_webpack_5_88_2_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__); var _node_modules_pnpm_css_loader_6_8_1_webpack_5_88_2_node_modules_css_loader_dist_runtime_getUrl_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(443); var _node_modules_pnpm_css_loader_6_8_1_webpack_5_88_2_node_modules_css_loader_dist_runtime_getUrl_js__WEBPACK_IMPORTED_MODULE_2___default = __webpack_require__.n(_node_modules_pnpm_css_loader_6_8_1_webpack_5_88_2_node_modules_css_loader_dist_runtime_getUrl_js__WEBPACK_IMPORTED_MODULE_2__); var ___CSS_LOADER_URL_IMPORT_0___ = new URL(__webpack_require__(591), __webpack_require__.b); var ___CSS_LOADER_URL_IMPORT_1___ = new URL(__webpack_require__(190), __webpack_require__.b); var ___CSS_LOADER_EXPORT___ = _node_modules_pnpm_css_loader_6_8_1_webpack_5_88_2_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()(_node_modules_pnpm_css_loader_6_8_1_webpack_5_88_2_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default()); var ___CSS_LOADER_URL_REPLACEMENT_0___ = _node_modules_pnpm_css_loader_6_8_1_webpack_5_88_2_node_modules_css_loader_dist_runtime_getUrl_js__WEBPACK_IMPORTED_MODULE_2___default()(___CSS_LOADER_URL_IMPORT_0___); var ___CSS_LOADER_URL_REPLACEMENT_1___ = _node_modules_pnpm_css_loader_6_8_1_webpack_5_88_2_node_modules_css_loader_dist_runtime_getUrl_js__WEBPACK_IMPORTED_MODULE_2___default()(___CSS_LOADER_URL_IMPORT_1___); ___CSS_LOADER_EXPORT___.push([ module.id, `.gosvon-reset-color-btn{border:0;border-radius:50%;margin-left:5px;height:20px;margin-top:3px;cursor:pointer;width:20px;transition:all .2s;opacity:.6}.gosvon-reset-color-btn:hover{opacity:.8}.gosvon-reset-color-btn:active{opacity:1}.gosvon-type-checkbox{display:flex;margin-bottom:2px}.gosvon-type-checkbox__label{margin-bottom:10px;width:180px}.gosvon-type-color{height:22px;border:0;cursor:pointer}.gosvon-type-name{width:180px}.gosvon-settings-modal{top:0;position:fixed;display:flex;flex-direction:column;justify-content:center;overflow:auto;z-index:1000;width:100%;height:100%}.gosvon-settings-modal-close{position:relative;float:right;padding:15px 20px 15px 15px;width:24px;height:24px;opacity:75%;color:var(--icon_medium);cursor:pointer;outline:0}.gosvon-settings-modal-title-wrap,.gosvon-advanced-menu-modal-permissions-denied-title-wrap{position:relative;padding:0;background-color:var(--background_content);color:var(--vkui--color_text_primary);border-bottom:1px solid var(--separator_common);border-radius:var(--vkui--size_border_radius_paper--regular, 8px) var(--vkui--size_border_radius_paper--regular, 8px) 0 0}.gosvon-settings-modal-title,.gosvon-advanced-menu-modal-permissions-denied-title{padding-left:25px;font-size:14px;color:var(--vkui--color_text_primary);height:54px;line-height:54px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gosvon-settings-container{width:100%;max-width:650px;box-shadow:0 2px 10px var(--black_alpha40);margin:20px auto}.gosvon-settings-modal-types{width:300px;overflow-y:scroll;padding-top:5px;padding-bottom:5px}.gosvon-settings-modal-marks{width:270px;height:273px;overflow-y:scroll;padding-top:5px;padding-bottom:5px}@keyframes glowing{0%{width:40px;height:40px;box-shadow:0 0 10px #f99,0 0 5px #f99;border:2px solid #f99}50%{width:30px;height:30px;box-shadow:0 0 10px #f99,0 0 5px #f99;border:2px solid #f99}100%{width:40px;height:40px;box-shadow:0 0 10px #f99,0 0 5px #f99;border:2px solid #f99}}.gosvon-replies-collecting-enabled-automatically{position:relative}.gosvon-replies-collecting-enabled-automatically::after{content:"";display:block;position:absolute;top:50%;left:50%;border-radius:50%;transform:translate(-50%, -50%);animation:glowing 1s 5;user-select:none}.gosvon-checkbox{display:flex;align-items:center;cursor:pointer;line-height:1.27em}.gosvon-checkbox input{display:none}.gosvon-checkbox input+.gosvon-checkbox-view{display:block;float:left;background-image:url(${___CSS_LOADER_URL_REPLACEMENT_0___});background-position:center;background-repeat:no-repeat;margin:0 7px 0 0;width:16px;height:16px;margin-top:-1px}.gosvon-checkbox input:checked+.gosvon-checkbox-view{background-image:url(${___CSS_LOADER_URL_REPLACEMENT_1___})}.gosvon-checkbox input:disabled+.gosvon-checkbox-view{filter:contrast(0)}.gosvon-checkbox:has(input:disabled){cursor:default}.gosvon-token-field-wrapper{margin-bottom:15px}.gosvon-token-line{position:relative;display:flex;flex-wrap:wrap;align-items:center;margin-bottom:5px;column-gap:10px}.gosvon-token-form-line{position:relative;display:flex;align-items:center;margin-bottom:5px}.gosvon-token-input-line{position:relative;display:flex;align-items:center;flex-wrap:wrap}.gosvon-token-field{box-sizing:border-box;display:block;padding:6px;height:33px;width:300px;font-family:monospace;border:1px solid #000;border-radius:3px}.gosvon-token-description{font-size:12px;color:var(--text_primary)}.gosvon-token-btn{position:absolute;top:4px;padding:0;height:25px;width:25px;border:1px solid #000;border-radius:3px;cursor:pointer}.gosvon-token-show-btn{right:34px}.gosvon-token-show-btn svg{width:16px;height:16px;vertical-align:middle;color:inherit;display:inline-block;fill:var(--vkui--color_text_primary)}.gosvon-token-clear-btn{right:4px}.gosvon-token-error{color:red}.gosvon-token-check-btn{box-sizing:border-box;height:33px;margin-left:5px;border:1px solid #000;border-radius:3px}.gosvon-token-info{position:relative;top:-3px;font-size:12px}.gosvon-settings-content,.gosvon-advanced-menu-modal-permissions-denied-description{padding:20px 25px;line-height:19px;overflow:auto;background-color:var(--background_content)}.gosvon-settings-content{height:450px}.gosvon-settings-modal-mobile{background:var(--background_content);overflow:auto}.gosvon-settings-modal-mobile .gosvon-settings-container{margin-top:0;height:unset}.gosvon-settings-modal-mobile .gosvon-settings-content{background:var(--background_content);height:unset}.gosvon-settings-modal-mobile .gosvon-settings-modal-hidden-mobile{display:none}.gosvon-settings-modal-mobile .gosvon-token-field{width:unset}.gosvon-settings-modal-mobile .gosvon-settings-modal-title-wrap{border-radius:0}.gosvon-settings-modal-checkboxes{display:flex;gap:10px;flex-wrap:wrap}.gosvon-advanced-menu-modal{position:fixed;top:0;left:0;bottom:0;right:0;z-index:9999;transition:all .2s;display:flex;flex-wrap:nowrap;flex-direction:row;align-items:safe center;justify-content:center}.gosvon-advanced-menu-modal-clickout-listener{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.4)}.gosvon-advanced-menu-modal-close{display:flex;justify-content:center;align-items:center;background:var(--background_content);border-radius:50px;position:absolute;right:10px;padding:10px;top:8px;height:45px;width:45px;cursor:pointer;box-sizing:border-box;transition:opacity .2s}.gosvon-advanced-menu-modal-close:hover{background:var(--background_hover)}.gosvon-advanced-menu-modal-content{position:relative;z-index:1;width:500px}.gosvon-advanced-menu-modal-content-mount{height:370px}#wk_likes_content{padding:20px}.gosvon-fan-table{width:100%;border-collapse:collapse}.gosvon-fan-table td{padding:0;border:1px solid rgba(0,0,0,.1882352941)}.gosvon-fan-table .gosvon-avatar{margin-right:3px;display:flex;align-items:center}.gosvon-fan-table .gosvon-name{display:flex;align-items:center}.gosvon-fan-table .gosvon-avatar img{transition:all .2s;pointer-events:none}.gosvon-fan-table .gosvon-avatar:hover img{transform:scale(10)}.bot-mark-or-type{position:absolute;left:60px;bottom:5px;font-size:10px;color:#000}.gosvon-profile-registration-date{opacity:.5;text-align:center}.gosvon-mobile-profile-bot-info{text-align:center;z-index:12;position:relative}.gosvon-reg-date{opacity:.5}.gosvon-mobile-reply-line{display:inline-block}.gosvon-desktop-fan{text-align:center;position:absolute;top:50%;transform:translateY(calc(-50% - 30px));left:0;width:100%;opacity:.7;color:#000}.gosvon-settings-mark{display:block;margin-bottom:10px}.gosvon-post-header{border-left:3px solid rgba(255,50,50,.3);padding-bottom:5px !important;padding-top:10px !important}.gosvon-post-line-old-design{display:inline-block;margin-top:5px;margin-bottom:5px}.gosvon-post-line{display:inline-block;margin-top:5px;margin-bottom:5px}.r .gosvon-post-mobile-header.wi_head{padding:5px !important;padding-top:17px !important}.gosvon-reply-form-btn{position:absolute;right:90px;background:0;border:0;top:2px;height:25px;width:25px;fill:#994168;padding:3px;cursor:pointer}.gosvon-profile-line{margin-top:5px;margin-bottom:5px}.gosvon-reply-actions{display:flex;align-items:center}.gosvon-reply-mobile-actions{display:inline-flex;align-items:center;transform:translate(0, 6px)}.gosvon-reply-action{margin-left:8px;overflow:visible;max-height:1em;height:16px;width:16px;visibility:hidden;fill:var(--vkui--color_text_primary)}@media(hover: none){.reply .gosvon-reply-action{visibility:visible;opacity:.5}}.reply:hover .gosvon-reply-action{visibility:visible;opacity:.5}.gosvon-reply-action:hover{opacity:.4}.gosvon-reply-mobile-action{margin-left:12px;overflow:visible;max-height:1em;height:21px;width:21px;opacity:.4;margin-top:-10px;fill:var(--vkui--color_text_primary)}.gosvon-reply-mobile-friend_action{margin-left:12px;overflow:visible;max-height:1em;height:21px;width:21px;opacity:.4;fill:var(--vkui--color_text_primary)}.gosvon-replies-collecting-description{width:21px;height:21px;fill:var(--text_link);transform:translateX(5px)}.gosvon-reply-content-from-bot{margin-top:-2px;padding-top:2px;margin-right:-2px;padding-right:2px;margin-bottom:-5px;padding-bottom:5px;border-left:3px solid rgba(255,50,50,.3);padding-left:2px}.gosvon-reply-mark-or-type{padding-left:2px;padding-right:2px;color:var(--gray_400)}.gosvon-mobile-friend-mark-or-type{padding-left:2px;padding-right:2px;margin-top:4px;color:var(--gray_400)}.gosvon-user-info-wrapper{height:100%;width:100%}.gosvon-notification{position:fixed;left:50px;bottom:20px;z-index:1501;background:rgba(0,0,0,.8);width:300px;padding:16px;color:#fff;border-radius:5px}@media(max-width: 800px){.gosvon-notification{left:10px;bottom:10px}}.gosvon-notification-logo{display:flex;align-items:center;font-size:10px;gap:10px;margin-bottom:10px}.gosvon-notification-close{position:absolute;right:5px;top:5px;opacity:.7;transition:all .2s;font-size:20px;font-weight:bold;display:flex;align-items:center;justify-content:center;height:25px;width:25px;cursor:pointer}.gosvon-notification-close:hover{opacity:1}.gosvon-notification-title{margin-bottom:10px;font-weight:bold}.gosvon-notification-text a{color:#54abff}.gosvon-mark-chip{padding:3px 6px;background:#000;border-radius:3px;color:#fff;margin-right:10px}.vkui--vkBase--dark .gosvon-mark-chip{background:#894646}.gosvon-highlight-overlay{position:absolute;width:100%;height:100%;pointer-events:none;top:0;left:0;opacity:.4}.gosvon-ib{display:inline-block}.gosvon-flex{display:flex}.gosvon-w-full{width:100%}.gosvon-tac{text-align:center}.gosvon-mono{font-family:monospace}.gosvon-mb-40{margin-bottom:30px}.gosvon-mb-30{margin-bottom:30px}.gosvon-mb-20{margin-bottom:20px}.gosvon-mb-10{margin-bottom:10px}.gosvon-mt-10{margin-top:10px}.gosvon-mt-40{margin-top:40px}.gosvon-mr-20{margin-right:20px}`, "" ]); const __WEBPACK_DEFAULT_EXPORT__ = ___CSS_LOADER_EXPORT___; }, 118: module => { "use strict"; /* MIT License http://www.opensource.org/licenses/mit-license.php Author Tobias Koppers @sokra */ module.exports = function(cssWithMappingToString) { var list = []; list.toString = function toString() { return this.map((function(item) { var content = ""; var needLayer = typeof item[5] !== "undefined"; if (item[4]) { content += "@supports (".concat(item[4], ") {"); } if (item[2]) { content += "@media ".concat(item[2], " {"); } if (needLayer) { content += "@layer".concat(item[5].length > 0 ? " ".concat(item[5]) : "", " {"); } content += cssWithMappingToString(item); if (needLayer) { content += "}"; } if (item[2]) { content += "}"; } if (item[4]) { content += "}"; } return content; })).join(""); }; list.i = function i(modules, media, dedupe, supports, layer) { if (typeof modules === "string") { modules = [ [ null, modules, undefined ] ]; } var alreadyImportedModules = {}; if (dedupe) { for (var k = 0; k < this.length; k++) { var id = this[k][0]; if (id != null) { alreadyImportedModules[id] = true; } } } for (var _k = 0; _k < modules.length; _k++) { var item = [].concat(modules[_k]); if (dedupe && alreadyImportedModules[item[0]]) { continue; } if (typeof layer !== "undefined") { if (typeof item[5] === "undefined") { item[5] = layer; } else { item[1] = "@layer".concat(item[5].length > 0 ? " ".concat(item[5]) : "", " {").concat(item[1], "}"); item[5] = layer; } } if (media) { if (!item[2]) { item[2] = media; } else { item[1] = "@media ".concat(item[2], " {").concat(item[1], "}"); item[2] = media; } } if (supports) { if (!item[4]) { item[4] = "".concat(supports); } else { item[1] = "@supports (".concat(item[4], ") {").concat(item[1], "}"); item[4] = supports; } } list.push(item); } }; return list; }; }, 443: module => { "use strict"; module.exports = function(url, options) { if (!options) { options = {}; } if (!url) { return url; } url = String(url.__esModule ? url.default : url); if (/^['"].*['"]$/.test(url)) { url = url.slice(1, -1); } if (options.hash) { url += options.hash; } if (/["'() \t\n]|(%20)/.test(url) || options.needQuotes) { return '"'.concat(url.replace(/"/g, '\\"').replace(/\n/g, "\\n"), '"'); } return url; }; }, 885: module => { "use strict"; module.exports = function(i) { return i[1]; }; }, 377: module => { module.exports = '<svg xmlns="http://www.w3.org/2000/svg" id="mdi-account-arrow-left-outline" viewBox="0 0 24 24"><path d="M17 18H21V16H17V14L14 17L17 20V18M11 4C8.8 4 7 5.8 7 8S8.8 12 11 12 15 10.2 15 8 13.2 4 11 4M11 6C12.1 6 13 6.9 13 8S12.1 10 11 10 9 9.1 9 8 9.9 6 11 6M11 13C8.3 13 3 14.3 3 17V20H12.5C12.2 19.4 12.1 18.8 12 18.1H4.9V17C4.9 16.4 8 14.9 11 14.9C11.5 14.9 12 15 12.5 15C12.8 14.4 13.1 13.8 13.6 13.3C12.6 13.1 11.7 13 11 13" /></svg>'; }, 797: module => { module.exports = '<svg xmlns="http://www.w3.org/2000/svg" id="mdi-account-box-outline" viewBox="0 0 24 24"><path d="M19,19H5V5H19M19,3H5A2,2 0 0,0 3,5V19A2,2 0 0,0 5,21H19A2,2 0 0,0 21,19V5C21,3.89 20.1,3 19,3M16.5,16.25C16.5,14.75 13.5,14 12,14C10.5,14 7.5,14.75 7.5,16.25V17H16.5M12,12.25A2.25,2.25 0 0,0 14.25,10A2.25,2.25 0 0,0 12,7.75A2.25,2.25 0 0,0 9.75,10A2.25,2.25 0 0,0 12,12.25Z" /></svg>'; }, 287: module => { module.exports = '<svg xmlns="http://www.w3.org/2000/svg" id="mdi-calendar-month-outline" viewBox="0 0 24 24"><path d="M7 11H9V13H7V11M21 5V19C21 20.11 20.11 21 19 21H5C3.89 21 3 20.1 3 19V5C3 3.9 3.9 3 5 3H6V1H8V3H16V1H18V3H19C20.11 3 21 3.9 21 5M5 7H19V5H5V7M19 19V9H5V19H19M15 13V11H17V13H15M11 13V11H13V13H11M7 15H9V17H7V15M15 17V15H17V17H15M11 17V15H13V17H11Z" /></svg>'; }, 531: module => { module.exports = '<svg xmlns="http://www.w3.org/2000/svg" id="mdi-eye-outline" viewBox="0 0 24 24"><path d="M12,9A3,3 0 0,1 15,12A3,3 0 0,1 12,15A3,3 0 0,1 9,12A3,3 0 0,1 12,9M12,4.5C17,4.5 21.27,7.61 23,12C21.27,16.39 17,19.5 12,19.5C7,19.5 2.73,16.39 1,12C2.73,7.61 7,4.5 12,4.5M3.18,12C4.83,15.36 8.24,17.5 12,17.5C15.76,17.5 19.17,15.36 20.82,12C19.17,8.64 15.76,6.5 12,6.5C8.24,6.5 4.83,8.64 3.18,12Z" /></svg>'; }, 656: module => { module.exports = '<svg xmlns="http://www.w3.org/2000/svg" id="mdi-information-slab-box-outline" viewBox="0 0 24 24"><path d="M11 9H13V7H11V9M14 17V15H13V11H10V13H11V15H10V17H14M5 3H19C20.1 3 21 3.89 21 5V19C21 19.53 20.79 20.04 20.41 20.41C20.04 20.79 19.53 21 19 21H5C4.47 21 3.96 20.79 3.59 20.41C3.21 20.04 3 19.53 3 19V5C3 3.89 3.89 3 5 3M19 19V5H5V19H19Z" /></svg>'; }, 41: module => { module.exports = '<svg xmlns="http://www.w3.org/2000/svg" id="mdi-information" viewBox="0 0 24 24"><path d="M13,9H11V7H13M13,17H11V11H13M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12A10,10 0 0,0 12,2Z" /></svg>'; }, 455: module => { module.exports = '<svg xmlns="http://www.w3.org/2000/svg" id="mdi-list-box-outline" viewBox="0 0 24 24"><path d="M11 15H17V17H11V15M9 7H7V9H9V7M11 13H17V11H11V13M11 9H17V7H11V9M9 11H7V13H9V11M21 5V19C21 20.1 20.1 21 19 21H5C3.9 21 3 20.1 3 19V5C3 3.9 3.9 3 5 3H19C20.1 3 21 3.9 21 5M19 5H5V19H19V5M9 15H7V17H9V15Z" /></svg>'; }, 886: module => { "use strict"; var stylesInDOM = []; function getIndexByIdentifier(identifier) { var result = -1; for (var i = 0; i < stylesInDOM.length; i++) { if (stylesInDOM[i].identifier === identifier) { result = i; break; } } return result; } function modulesToDom(list, options) { var idCountMap = {}; var identifiers = []; for (var i = 0; i < list.length; i++) { var item = list[i]; var id = options.base ? item[0] + options.base : item[0]; var count = idCountMap[id] || 0; var identifier = "".concat(id, " ").concat(count); idCountMap[id] = count + 1; var indexByIdentifier = getIndexByIdentifier(identifier); var obj = { css: item[1], media: item[2], sourceMap: item[3], supports: item[4], layer: item[5] }; if (indexByIdentifier !== -1) { stylesInDOM[indexByIdentifier].references++; stylesInDOM[indexByIdentifier].updater(obj); } else { var updater = addElementStyle(obj, options); options.byIndex = i; stylesInDOM.splice(i, 0, { identifier, updater, references: 1 }); } identifiers.push(identifier); } return identifiers; } function addElementStyle(obj, options) { var api = options.domAPI(options); api.update(obj); var updater = function updater(newObj) { if (newObj) { if (newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap && newObj.supports === obj.supports && newObj.layer === obj.layer) { return; } api.update(obj = newObj); } else { api.remove(); } }; return updater; } module.exports = function(list, options) { options = options || {}; list = list || []; var lastIdentifiers = modulesToDom(list, options); return function update(newList) { newList = newList || []; for (var i = 0; i < lastIdentifiers.length; i++) { var identifier = lastIdentifiers[i]; var index = getIndexByIdentifier(identifier); stylesInDOM[index].references--; } var newLastIdentifiers = modulesToDom(newList, options); for (var _i = 0; _i < lastIdentifiers.length; _i++) { var _identifier = lastIdentifiers[_i]; var _index = getIndexByIdentifier(_identifier); if (stylesInDOM[_index].references === 0) { stylesInDOM[_index].updater(); stylesInDOM.splice(_index, 1); } } lastIdentifiers = newLastIdentifiers; }; }; }, 122: module => { "use strict"; var memo = {}; function getTarget(target) { if (typeof memo[target] === "undefined") { var styleTarget = document.querySelector(target); if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) { try { styleTarget = styleTarget.contentDocument.head; } catch (e) { styleTarget = null; } } memo[target] = styleTarget; } return memo[target]; } function insertBySelector(insert, style) { var target = getTarget(insert); if (!target) { throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid."); } target.appendChild(style); } module.exports = insertBySelector; }, 611: module => { "use strict"; function insertStyleElement(options) { var element = document.createElement("style"); options.setAttributes(element, options.attributes); options.insert(element, options.options); return element; } module.exports = insertStyleElement; }, 791: (module, __unused_webpack_exports, __webpack_require__) => { "use strict"; function setAttributesWithoutAttributes(styleElement) { var nonce = true ? __webpack_require__.nc : 0; if (nonce) { styleElement.setAttribute("nonce", nonce); } } module.exports = setAttributesWithoutAttributes; }, 788: module => { "use strict"; function apply(styleElement, options, obj) { var css = ""; if (obj.supports) { css += "@supports (".concat(obj.supports, ") {"); } if (obj.media) { css += "@media ".concat(obj.media, " {"); } var needLayer = typeof obj.layer !== "undefined"; if (needLayer) { css += "@layer".concat(obj.layer.length > 0 ? " ".concat(obj.layer) : "", " {"); } css += obj.css; if (needLayer) { css += "}"; } if (obj.media) { css += "}"; } if (obj.supports) { css += "}"; } var sourceMap = obj.sourceMap; if (sourceMap && typeof btoa !== "undefined") { css += "\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), " */"); } options.styleTagTransform(css, styleElement, options.options); } function removeStyleElement(styleElement) { if (styleElement.parentNode === null) { return false; } styleElement.parentNode.removeChild(styleElement); } function domAPI(options) { if (typeof document === "undefined") { return { update: function update() {}, remove: function remove() {} }; } var styleElement = options.insertStyleElement(options); return { update: function update(obj) { apply(styleElement, options, obj); }, remove: function remove() { removeStyleElement(styleElement); } }; } module.exports = domAPI; }, 671: module => { "use strict"; function styleTagTransform(css, styleElement) { if (styleElement.styleSheet) { styleElement.styleSheet.cssText = css; } else { while (styleElement.firstChild) { styleElement.removeChild(styleElement.firstChild); } styleElement.appendChild(document.createTextNode(css)); } } module.exports = styleTagTransform; }, 190: module => { "use strict"; module.exports = "data:image/svg+xml;charset=utf-8,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M2.44%204.18C2%205.04%202%206.16%202%208.4v3.2c0%202.24%200%203.36.44%204.22a4%204%200%20001.74%201.74c.86.44%201.98.44%204.22.44h3.2c2.24%200%203.36%200%204.22-.44a4%204%200%20001.74-1.74c.44-.86.44-1.98.44-4.22V8.4c0-2.24%200-3.36-.44-4.22a4%204%200%2000-1.74-1.74C14.96%202%2013.84%202%2011.6%202H8.4c-2.24%200-3.36%200-4.22.44a4%204%200%2000-1.74%201.74zm12.2%203.8a.9.9%200%2010-1.28-1.27L8.7%2011.38%206.64%209.33a.9.9%200%2000-1.28%201.27l2.7%202.69a.9.9%200%20001.27%200l5.3-5.3z%22%20fill%3D%22%235181b8%22%2F%3E%3C%2Fsvg%3E"; }, 591: module => { "use strict"; module.exports = "data:image/svg+xml;charset=utf-8,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M4.05%202.53C4.79%202.13%205.52%202%207.13%202h5.74c1.61%200%202.34.14%203.08.53.65.35%201.17.87%201.52%201.52.4.74.53%201.47.53%203.08v5.74c0%201.61-.14%202.34-.53%203.08a3.64%203.64%200%2001-1.52%201.52c-.74.4-1.47.53-3.08.53H7.13c-1.61%200-2.34-.14-3.08-.53a3.64%203.64%200%2001-1.52-1.52c-.4-.74-.53-1.47-.53-3.08V7.13c0-1.61.14-2.34.53-3.08a3.65%203.65%200%20011.52-1.52zm3.08.97c-1.53%200-1.96.14-2.38.36a2.15%202.15%200%2000-.9.9c-.21.4-.35.84-.35%202.37v5.74c0%201.53.14%201.96.36%202.38.2.39.5.69.9.9.4.21.84.35%202.37.35h5.74c1.53%200%201.96-.14%202.38-.36.39-.2.69-.5.9-.9.21-.4.35-.84.35-2.37V7.13c0-1.53-.14-1.96-.36-2.38a2.15%202.15%200%2000-.9-.9c-.4-.21-.84-.35-2.37-.35H7.13z%22%20fill%3D%22%23aeb7c2%22%2F%3E%3C%2Fsvg%3E"; } }; var __webpack_module_cache__ = {}; function __webpack_require__(moduleId) { var cachedModule = __webpack_module_cache__[moduleId]; if (cachedModule !== undefined) { return cachedModule.exports; } var module = __webpack_module_cache__[moduleId] = { id: moduleId, exports: {} }; __webpack_modules__[moduleId](module, module.exports, __webpack_require__); return module.exports; } __webpack_require__.m = __webpack_modules__; (() => { __webpack_require__.n = module => { var getter = module && module.__esModule ? () => module["default"] : () => module; __webpack_require__.d(getter, { a: getter }); return getter; }; })(); (() => { __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_require__.o = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop); })(); (() => { __webpack_require__.b = document.baseURI || self.location.href; // undefined = chunk not loaded, null = chunk preloaded/prefetched // [resolve, reject, Promise] = chunk loading, 0 = chunk loaded var installedChunks = { 179: 0 }; })(); (() => { __webpack_require__.nc = undefined; })(); var __webpack_exports__ = {}; (() => { "use strict"; /* eslint-disable @typescript-eslint/naming-convention */ /* eslint-enable @typescript-eslint/naming-convention */ const http = GM_xmlhttpRequest || GM && GM.xmlHttpRequest; if (!http) { throw new Error("Unable to get supported cross-origin XMLHttpRequest function."); } const gmUtils = { async http(options) { return new Promise((resolve => { http({ url: options.url, method: options.method || "GET", overrideMimeType: options.mime || "application/json; charset=utf-8", data: options.data, async onload(response) { resolve(response.responseText); } }); })); }, unsafeWindow, setStorageValue: GM_setValue, getStorageValue: GM_getValue, deleteStorageValue: GM_deleteValue }; const tryTo = act => { try { return act(); } catch {} return undefined; }; const createStorageValueMigrator = ({storageName, defaultValue, migrations = []}) => { const versionStorageName = `${storageName}__version__`; const currentVersion = migrations?.length || 0; const getUserValueVersion = value => { if (value === defaultValue) { return currentVersion; } const versionInUserStorage = gmUtils.getStorageValue(versionStorageName); if (typeof versionInUserStorage === "undefined") { return 0; } return versionInUserStorage; }; const getUserValue = () => { const realValue = gmUtils.getStorageValue(storageName); const parsedValue = tryTo((() => JSON.parse(realValue))); const computedValue = typeof defaultValue === "object" ? parsedValue ?? defaultValue : realValue; return computedValue; }; const set = newValue => { gmUtils.setStorageValue(storageName, JSON.stringify(newValue)); gmUtils.setStorageValue(versionStorageName, currentVersion); }; const get = () => { const userStorageValue = getUserValue(); const appliedMigrationsCount = getUserValueVersion(userStorageValue); const notAppliedMigrations = migrations.slice(appliedMigrationsCount); const migratedValue = notAppliedMigrations.reduce(((lastRes, migration) => migration(lastRes)), userStorageValue); return migratedValue; }; return { get, set }; }; const UserCache_createStorageValueMigrator = createStorageValueMigrator; var EKnownStorages = function(EKnownStorages) { EKnownStorages["CONFIG"] = "botHighlighterSavedConfig"; return EKnownStorages; }(EKnownStorages || {}); const KnownStorages = EKnownStorages; const createIDTrueMap = array => array.reduce(((acc, it) => ({ ...acc, [it]: true })), {}); function processRawConfig(rawConfig) { const types = rawConfig.types.map((rawTypeItem => ({ id: rawTypeItem.id, name: rawTypeItem.n, serverColor: rawTypeItem.color, shouldShowActions: Boolean(rawTypeItem.links), switchable: Boolean(rawTypeItem.disabling) }))); const marks = rawConfig.mark.map((rawMarkItem => ({ id: rawMarkItem.id, name: rawMarkItem.n }))); return { botListVersion: String(rawConfig.timestamp), types, marks, wallsIdsWithDisabledReplyCollecting: createIDTrueMap(rawConfig.wall_skips), message: rawConfig.message, proxy: rawConfig.proxy }; } const stateCache = UserCache_createStorageValueMigrator({ storageName: KnownStorages.CONFIG, defaultValue: { botListVersion: "0", types: [], marks: [], wallsIdsWithDisabledReplyCollecting: {}, proxy: "" }, migrations: [ s => ({ ...s, wallsIdsWithDisabledReplyCollecting: {} }), s => ({ ...s, proxy: "" }) ] }); async function configStoreFactory(DI) { const state = stateCache.get(); console.log("GosVon. Конфиг по умолчанию", JSON.parse(JSON.stringify(state)), gmUtils); async function saveState() { stateCache.set(state); } async function fetchConfig() { const lastRequest = { date: Date.now() }; gmUtils.setStorageValue("gosvon_config_request", JSON.stringify(lastRequest)); const urls = [ "https://api.gosvon.net/marking3/main", "https://gosvon.github.io/gosvon/main" ]; let shouldUseProxyAsMainHost = false; for (const url of urls) { try { const responseText = await gmUtils.http({ url }); const parsedConfig = processRawConfig(JSON.parse(responseText)); console.log("GosVon: Получен новый конфиг", parsedConfig); Object.assign(state, parsedConfig); saveState(); lastRequest.result = parsedConfig; gmUtils.setStorageValue("gosvon_config_request", JSON.stringify(lastRequest)); if (shouldUseProxyAsMainHost) { DI.host = state.proxy; } return; } catch (e) { shouldUseProxyAsMainHost = true; } } } const initialize = async () => { if (hasConfigRequestInProgress()) { await waitForExistingConfigRequestResult({ onTimeout: () => fetchConfig() }); } else { await fetchConfig(); } }; await initialize(); return { state }; } const REQUEST_TIMEOUT = 2e4; function getLastConfigRequest() { try { return JSON.parse(gmUtils.getStorageValue("gosvon_config_request")); } catch { return undefined; } } function hasConfigRequestInProgress() { const lastConfigRequest = getLastConfigRequest(); if (!lastConfigRequest) { return false; } const now = Date.now(); const configAliveTill = lastConfigRequest.date + REQUEST_TIMEOUT; const isRequestTimeoutPassed = now > configAliveTill; return !lastConfigRequest.result && !isRequestTimeoutPassed; } function waitForExistingConfigRequestResult({onTimeout}) { return new Promise((resolve => { let timeout = null; const checkResultInterval = setInterval((() => { const lastConfigRequest = getLastConfigRequest(); if (lastConfigRequest?.result) { clearTimeout(timeout); clearInterval(checkResultInterval); resolve(lastConfigRequest.result); } }), 100); timeout = setTimeout((() => { clearInterval(checkResultInterval); resolve(onTimeout()); }), REQUEST_TIMEOUT); })); } async function botListsFactory(DI) { let botList = []; async function fetchBotList() { const urls = [ "https://api.gosvon.net/marking3/list", "https://gosvon.github.io/gosvon/list" ]; for (const url of urls) { try { const responseText = await gmUtils.http({ url }); return JSON.parse(responseText); } catch (e) {} } return null; } function saveBotList(rawBotList) { gmUtils.setStorageValue("botHighlighterSavedBotList", JSON.stringify(rawBotList)); } function saveBotListVersion() { gmUtils.setStorageValue("botHighlighterBotListVersion", DI.config.state.botListVersion); } async function getSavedBotList() { return JSON.parse(gmUtils.getStorageValue("botHighlighterSavedBotList") || "[]"); } function getSavedBotListVersion() { return gmUtils.getStorageValue("botHighlighterBotListVersion") || "0"; } async function getBotList() { const localBotListVersion = getSavedBotListVersion(); if (DI.config.state.botListVersion <= localBotListVersion) { return getSavedBotList(); } const fetchedBotList = await fetchBotList(); if (!fetchedBotList) { return getSavedBotList(); } saveBotList(fetchedBotList); saveBotListVersion(); return fetchedBotList; } async function fillLists() { const rawBotList = await getBotList(); botList = rawBotList.map((rawBot => { DI.botCounter.incrementBotCountByType(Number(rawBot.t)); if (rawBot.m) { DI.botCounter.incrementBotCountByMark(rawBot.m); } const mark = DI.config.state.marks.find((markItem => markItem.id === rawBot.m)); const type = DI.config.state.types.find((typeItem => typeItem.id === Number(rawBot.t))); return { id: Number(rawBot.i), nickname: rawBot.n, mark, type }; })); } await fillLists(); return botList; } const STORE_KEY = "botHighlighterSettings"; function userSettingsFactory(DI) { const saved = gmUtils.getStorageValue(STORE_KEY); const stateWatchers = []; const state = { disabledMarksIds: saved?.disabledMarksIds || [], disabledTypesIds: saved?.disabledTypesIds || [], customTypesColors: saved?.customTypesColors || {}, isFansTableViewEnabled: saved?.isFansTableViewEnabled ?? false, isRepliesCollectingEnabled: saved?.isRepliesCollectingEnabled ?? false, isRepliesCollectingEnabledAutomatically: false }; const mapTypeToColorApplier = {}; const dispatchStateUpdate = () => { stateWatchers.forEach((it => it(state))); }; const update = updator => { Object.assign(state, updator(state)); dispatchStateUpdate(); gmUtils.setStorageValue(STORE_KEY, { disabledMarksIds: state.disabledMarksIds, disabledTypesIds: state.disabledTypesIds, customTypesColors: state.customTypesColors, isFansTableViewEnabled: state.isFansTableViewEnabled, isRepliesCollectingEnabled: state.isRepliesCollectingEnabled }); }; const onStateUpdate = newStateWatcher => { stateWatchers.push(newStateWatcher); dispatchStateUpdate(); }; const disableMark = markId => { state.disabledMarksIds = [ ...state.disabledMarksIds, markId ]; update((s => ({ ...s, disabledMarksIds: [ ...s.disabledMarksIds, markId ] }))); }; const disableType = typeId => { update((s => ({ ...s, disabledTypesIds: [ ...state.disabledTypesIds, typeId ] }))); }; const enableMark = markId => { update((s => ({ ...s, disabledMarksIds: s.disabledMarksIds.filter((markIdItem => markIdItem !== markId)) }))); }; const setIsFansTableViewEnabled = isFansTableViewEnabled => { update((s => ({ ...s, isFansTableViewEnabled }))); }; const setIsRepliesCollectingEnabled = isRepliesCollectingEnabled => { update((s => ({ ...s, isRepliesCollectingEnabled }))); }; const automaticallyEnableRepliesCollecting = () => { update((s => ({ ...s, isRepliesCollectingEnabled: true, isRepliesCollectingEnabledAutomatically: true }))); }; const enableType = typeId => { update((s => ({ ...s, disabledTypesIds: s.disabledTypesIds.filter((typeIdItem => typeIdItem !== typeId)) }))); }; const triggerWatchers = typeId => { mapTypeToColorApplier[typeId]?.forEach(((cb, index) => { try { cb(state.customTypesColors[typeId]); } catch { mapTypeToColorApplier[typeId].splice(index, 1); } })); }; const setCustomTypeColor = (typeId, color) => { update((s => ({ ...s, customTypesColors: { ...s.customTypesColors, [typeId]: color } }))); triggerWatchers(typeId); }; const removeCustomTypeColor = typeId => { delete state.customTypesColors[typeId]; update((s => ({ ...s }))); triggerWatchers(typeId); }; const checkIsMarkDisabled = markId => state.disabledMarksIds.includes(markId); const checkIsTypeDisabled = typeId => state.disabledTypesIds.includes(typeId); const getCustomTypeColor = typeId => state.customTypesColors[typeId]; const onChangeCustomColor = (typeId, cb) => { mapTypeToColorApplier[typeId] = [ ...mapTypeToColorApplier[typeId] || [], cb ]; cb(state.customTypesColors[typeId]); }; const onLayoutInjected = () => { if (!DI.tokenStore.state.userToken) { setIsRepliesCollectingEnabled(false); } }; const initialize = () => { DI.config.state.types.forEach((typeItem => { if (!typeItem.switchable) { enableType(typeItem.id); } })); }; initialize(); return { state, onStateUpdate, enableMark, enableType, disableMark, disableType, checkIsMarkDisabled, checkIsTypeDisabled, getCustomTypeColor, onChangeCustomColor, setCustomTypeColor, removeCustomTypeColor, setIsFansTableViewEnabled, setIsRepliesCollectingEnabled, automaticallyEnableRepliesCollecting, onLayoutInjected }; } function botCounterFactory(DI) { const state = { types: {}, marks: {} }; function fillCounters() { DI.config.state.types.forEach((botType => { if (!state.types[botType.id]) { state.types[botType.id] = 0; } state.types[botType.id] += 1; })); DI.config.state.marks.forEach((botMark => { if (!state.marks[botMark.id]) { state.marks[botMark.id] = 0; } state.marks[botMark.id] += 1; })); } function incrementBotCountByType(typeId) { state.types[typeId] += 1; } function incrementBotCountByMark(markId) { state.marks[markId] += 1; } fillCounters(); return { state, incrementBotCountByType, incrementBotCountByMark }; } function formatDate(date) { const addZero = num => num < 10 ? `0${num}` : num; const month = addZero(date.getMonth() + 1); const year = addZero(date.getFullYear()); const day = addZero(date.getDate()); const hour = addZero(date.getHours()); const minute = addZero(date.getMinutes()); const second = addZero(date.getSeconds()); return `${day}.${month}.${year} ${hour}:${minute}:${second}`; } function registrationDatesFactory() { const state = { registrationDates: {}, mapUserIdToWatchers: {} }; const triggerRegistrationDatesWatchers = userId => { state.mapUserIdToWatchers[userId]?.forEach(((cb, index) => { try { cb(state.registrationDates[userId]); } catch { state.mapUserIdToWatchers[userId].splice(index, 1); } })); }; const fetchUserId = async nickname => { const userIdResponse = await gmUtils.http({ url: `https://vk.com/${nickname}`, mime: "application/json; charset=windows-1251" }); return userIdResponse.match(/"owner_id":(\d+)/)?.[1]; }; const fetchRegistrationDate = async userIdOrNickName => { const existingUserRegistrationDate = state.registrationDates[userIdOrNickName]; if (existingUserRegistrationDate) { return existingUserRegistrationDate; } const userId = userIdOrNickName.match(/^(id)?\d+$/) ? userIdOrNickName.replace(/^id/, "") : await fetchUserId(userIdOrNickName); console.log(`GosVon: ID пользователя ${userId}`); const userInfoResponse = await gmUtils.http({ url: `https://vk.com/foaf.php?id=${userId}`, mime: "application/json; charset=windows-1251" }); const matchResponseDate = userInfoResponse.match(/<ya:created dc:date="(.+)"\/>/)?.[1]; if (!matchResponseDate) { console.log(`GosVon: Дата регистрации не найдена ${userId}`, userInfoResponse); if (userInfoResponse.match(/<ya:profileState>banned<\/ya:profileState>/)) { const errorText = "Аккаунт забанен. Нельзя получить дату регистрации"; state.registrationDates[userIdOrNickName] = errorText; triggerRegistrationDatesWatchers(userIdOrNickName); return errorText; } const errorText = "Не удалось получить дату регистрации"; state.registrationDates[userIdOrNickName] = errorText; triggerRegistrationDatesWatchers(userIdOrNickName); return errorText; } const date = new Date(matchResponseDate); if (!date) { return ""; } const userRegistrationDate = `Дата регистрации: ${formatDate(date)}`; state.registrationDates[userIdOrNickName] = userRegistrationDate; triggerRegistrationDatesWatchers(userIdOrNickName); return userRegistrationDate; }; const onChangeRegistrationDate = (userId, watcher) => { state.mapUserIdToWatchers[userId] = [ ...state.mapUserIdToWatchers[userId] || [], watcher ]; watcher(state.registrationDates[userId]); }; return { fetchRegistrationDate, onChangeRegistrationDate }; } function advancedMenuStoreFactory(DI) { const state = { iframeEl: null }; const saveModalElement = iframeEl => { state.iframeEl = iframeEl; }; const updateMenu = async data => { if (!state.iframeEl?.parentElement) { return; } state.iframeEl?.contentWindow?.postMessage(JSON.stringify({ ...data, token: DI.tokenStore.state.userToken, tokenLevel: DI.tokenStore.state.tokenLevel, tokenPoints: DI.tokenStore.state.tokenPoints || null, host: DI.host }), "MISSING_ENV_VAR".ADVANCED_MENU_IFRAME_SRC || `${DI.host}/script/AdvMenu/`); }; return { saveModalElement, updateMenu }; } const constants = { REPLIES_SAVE_AFTER_COUNT: 500, MAX_REPLIES_IDS_COUNT_FOR_SAVING: 3e3 }; const src_constants = constants; function transformReplyDataForServer(replies) { return replies.reduce(((acc, replyData) => { const addedPost = acc.find((it => it.post === replyData.postId && it.wall === replyData.wallId)); const replyDataInServerFormat = { reply_id: replyData.replyId, user_id: replyData.userId }; if (addedPost) { addedPost.comms.push(replyDataInServerFormat); } else { const postDataInServerFormat = { wall: replyData.wallId, nick: replyData.wallSlug, post: replyData.postId, count: replyData.repliesCount, comms: [ replyDataInServerFormat ] }; acc.push(postDataInServerFormat); } return acc; }), []); } const STATE_KEY = "gosvonRepliesStore"; function replyCollectorFactory(DI) { const savedState = gmUtils.getStorageValue(STATE_KEY); const state = { repliesForSending: savedState?.repliesForSending || [], latestSentRepliesIds: savedState?.latestSentRepliesIds || [], lastSendTime: savedState?.lastSendTime || 0 }; let latestSentRepliesIdsIndexed = {}; const makeIndexedLatestSentRepliesIds = () => { latestSentRepliesIdsIndexed = state.latestSentRepliesIds.reduce(((acc, id) => ({ ...acc, [id]: true })), {}); }; makeIndexedLatestSentRepliesIds(); const saveState = () => { gmUtils.setStorageValue(STATE_KEY, state); }; const updateLatestSentRepliesIds = sentReplies => { const exceedingCount = Math.max(0, state.latestSentRepliesIds.length + sentReplies.length - src_constants.MAX_REPLIES_IDS_COUNT_FOR_SAVING); const limitedOldLatestSentRepliesIds = state.latestSentRepliesIds.slice(exceedingCount); const newLatestSentRepliesIds = [ ...limitedOldLatestSentRepliesIds, ...sentReplies.map((it => it.replyId)) ]; console.log("Gosvon. Кеширование недавно отправленных комментариев", { sentReplies, MAX_REPLIES_IDS_COUNT_FOR_SAVING: src_constants.MAX_REPLIES_IDS_COUNT_FOR_SAVING, needToRemoveOld: state.latestSentRepliesIds.length > src_constants.MAX_REPLIES_IDS_COUNT_FOR_SAVING, currentLatestSentRepliesIds: state.latestSentRepliesIds, limitedOldLatestSentRepliesIds, newLatestSentRepliesIds }); state.latestSentRepliesIds = newLatestSentRepliesIds; makeIndexedLatestSentRepliesIds(); }; async function sendReplies() { const checkShouldSend = () => { const sinceLastSendTime = Date.now() - state.lastSendTime; const shouldSend = state.repliesForSending.length >= src_constants.REPLIES_SAVE_AFTER_COUNT && sinceLastSendTime > 1 * 60 * 1e3 || state.repliesForSending.length > 0 && sinceLastSendTime > 10 * 60 * 1e3; return shouldSend; }; if (!checkShouldSend()) { return; } try { const sentReplies = state.repliesForSending.slice(); const sendingData = transformReplyDataForServer(sentReplies); console.log("GosVon. Сохранение комментов. Запрос:", { sendingData }); const response = await gmUtils.http({ url: `${DI.host}/script/get.php?code=${DI.tokenStore.state.userToken}`, method: "POST", data: JSON.stringify(sendingData) }); console.log("GosVon. Сохранение комментов. Ответ:", { response }); state.repliesForSending = state.repliesForSending.slice(sentReplies.length); state.lastSendTime = Date.now().valueOf(); updateLatestSentRepliesIds(sentReplies); saveState(); } catch (e) { console.error("GosVon. Сохранение комментов. Ошибка:", e); } } const killSwitch = () => { if (state.repliesForSending.length > src_constants.REPLIES_SAVE_AFTER_COUNT * 3) { state.repliesForSending = []; state.latestSentRepliesIds = []; saveState(); makeIndexedLatestSentRepliesIds(); DI.userSettings.setIsRepliesCollectingEnabled(false); throw new Error("Gosvon: ReplyCollector. KILL_SWITCH"); } }; let debounceTimeoutId = -1; const add = replyData => { killSwitch(); if (!DI.tokenStore.state.userToken) { return; } const isReplyOnPageWithDisabledCollecting = DI.config.state.wallsIdsWithDisabledReplyCollecting[replyData.wallId]; if (isReplyOnPageWithDisabledCollecting) { console.log(`GosVon. Сбор комментариев отключен для страницы с ID ${replyData.wallId}`); return; } const isReplyRecentlySent = latestSentRepliesIdsIndexed[replyData.replyId]; if (isReplyRecentlySent) { return; } const isReplyAlreadyAdded = state.repliesForSending.some((it => it.wallId === replyData.wallId && it.postId === replyData.postId && it.replyId === replyData.replyId && it.userId === replyData.userId)); if (isReplyAlreadyAdded) { return; } state.repliesForSending.push(replyData); clearTimeout(debounceTimeoutId); debounceTimeoutId = setTimeout((() => { saveState(); sendReplies(); }), 1e3); }; const clearCache = () => { Object.assign(state, { repliesForSending: [], latestSentRepliesIds: [] }); saveState(); }; return { state, add, clearCache }; } let ETokenPermissions = function(ETokenPermissions) { ETokenPermissions["CAN_OPEN_ADVANCED_MENU"] = "CAN_OPEN_ADVANCED_MENU"; return ETokenPermissions; }({}); const tokenStoreFactory_STORE_KEY = "gosvonTokenStore8"; function tokenStoreFactory(DI) { const saved = gmUtils.getStorageValue(tokenStoreFactory_STORE_KEY); const stateWatchers = []; const state = { isTokenCheckingInProgress: false, errorMessage: "", userToken: saved?.userToken || "", tokenLevel: saved?.tokenLevel || null, tokenPoints: saved?.tokenPoints || null, expires: saved?.expires ? new Date(saved?.expires) : null, isTokenShown: false }; const dispatchStateUpdate = () => { const getComputedPermissions = () => [ ...state.tokenLevel && state.tokenLevel > 0 || state.tokenPoints && state.tokenPoints > 0 ? [ ETokenPermissions.CAN_OPEN_ADVANCED_MENU ] : [] ]; const getComputedStyle = () => ({ permissions: getComputedPermissions() }); stateWatchers.forEach((it => it({ ...state, ...getComputedStyle() }))); }; const update = updator => { Object.assign(state, updator(state)); dispatchStateUpdate(); gmUtils.setStorageValue(tokenStoreFactory_STORE_KEY, { ...state, expires: state.expires ? Number(state.expires) : null }); }; const onStateUpdate = newStateWatcher => { stateWatchers.push(newStateWatcher); dispatchStateUpdate(); }; const checkToken = async () => { const tokenField = document.querySelector(".gosvon-token-field"); const checkingToken = tokenField?.value || ""; if (!tokenField || !checkingToken) { return; } update((s => ({ ...s, errorMessage: "", tokenLevel: null, tokenPoints: null, expires: null, isTokenCheckingInProgress: true }))); try { const responseText = await gmUtils.http({ url: `${DI.host}/script/?code=${checkingToken}&t=getMe` }); console.log("GosVon. Проверка кода:", responseText); const parsed = JSON.parse(responseText); if (parsed.error) { update((s => ({ ...s, errorMessage: parsed.error }))); DI.userSettings.setIsRepliesCollectingEnabled(false); return; } console.log("GosVon. Код:", responseText); if (state.userToken !== checkingToken) { DI.userSettings.automaticallyEnableRepliesCollecting(); } update((s => ({ ...s, userToken: checkingToken, tokenLevel: Number(parsed.response.access), tokenPoints: Number(parsed.response.points) || null, expires: new Date(Number(`${parsed.response.til}000`)), isTokenShown: false }))); } catch (e) { console.warn("GosVon. Ошибка проверки кода:", e); } finally { update((s => ({ ...s, isTokenCheckingInProgress: false }))); } }; const toggleTokenShow = () => { update((s => ({ ...s, isTokenShown: !s.isTokenShown }))); }; const autoCheckToken = () => { const lastCheckDate = gmUtils.getStorageValue("gosvonLastTokenAutoCheck") || 0; const now = Date.now().valueOf(); const sinceLastCheck = now - lastCheckDate; const TWENTY_MINUTES = 20 * 6e4; if (sinceLastCheck < TWENTY_MINUTES) { const minutesRest = Math.ceil((TWENTY_MINUTES - sinceLastCheck) / 60 / 1e3); console.log(`GosVon. Автоматическая проверка кода возможна через: ${minutesRest} мин.`); return; } console.log("GosVon. Автоматическая проверка кода"); checkToken(); gmUtils.setStorageValue("gosvonLastTokenAutoCheck", Date.now().valueOf()); }; const clearToken = () => { DI.userSettings.setIsRepliesCollectingEnabled(false); update((s => ({ ...s, userToken: "", tokenLevel: null, tokenPoints: null, expires: null }))); }; const onLayoutInjected = () => { dispatchStateUpdate(); autoCheckToken(); setInterval(autoCheckToken, 8 * 60 * 6e4); }; return { state, checkToken, onStateUpdate, onLayoutInjected, toggleTokenShow, clearToken }; } const DI = { botList: {}, userSettings: {}, config: {}, botCounter: {}, registrationDates: {}, advancedMenuStore: {}, replyCollector: {}, tokenStore: {}, host: "https://gosvon.net" }; async function getDIReady() { DI.config = await configStoreFactory(DI); DI.userSettings = userSettingsFactory(DI); DI.tokenStore = tokenStoreFactory(DI); if (!DI.config.state.botListVersion) { throw new Error("GosVon: Не могу получить конфигурацию"); } DI.replyCollector = replyCollectorFactory(DI); DI.botCounter = botCounterFactory(DI); DI.registrationDates = registrationDatesFactory(); DI.advancedMenuStore = advancedMenuStoreFactory(DI); DI.botList = await botListsFactory(DI); return DI; } const src_DI = DI; function changeBotFilterEnabledState(filterId, input, filterType) { const isEnabled = input.checked; if (filterType === "mark") { if (isEnabled) { src_DI.userSettings.enableMark(filterId); } else { src_DI.userSettings.disableMark(filterId); } } if (filterType === "type") { const typeId = Number(filterId); if (isEnabled) { src_DI.userSettings.enableType(typeId); } else { src_DI.userSettings.disableType(typeId); } } } function checkToken() { src_DI.tokenStore.checkToken(); } function closeSettingsModal() { const modal = document.querySelector(".gosvon-js-settings-modal"); if (!modal) { return; } modal.style.display = "none"; } function fetchUserRegistrationDate(userId) { src_DI.registrationDates.fetchRegistrationDate(userId); } function openAdvancedUserInfoModal(userIdOrNickname, replyLink, userName, userAvatar) { const modal = document.querySelector(".gosvon-advanced-menu-modal"); if (!modal) { return; } modal.style.pointerEvents = "unset"; modal.style.opacity = "1"; src_DI.advancedMenuStore.updateMenu({ userIdOrNickname, userName, replyLink, userAvatar }); } function openSettingsModal() { const modal = document.querySelector(".gosvon-js-settings-modal"); if (!modal) { return; } modal.style.display = "block"; } function removeCustomTypeColor(typeId) { src_DI.userSettings.removeCustomTypeColor(typeId); } function setCustomTypeColor(typeId, color) { src_DI.userSettings.setCustomTypeColor(typeId, color); } function setIsFansTableViewEnabled(input) { src_DI.userSettings.setIsFansTableViewEnabled(input.checked); } function toggleTokenShow() { src_DI.tokenStore.toggleTokenShow(); } function setIsRepliesCollectingEnabled(input) { src_DI.userSettings.setIsRepliesCollectingEnabled(input.checked); } function clearToken() { const tokenField = document.querySelector(".gosvon-token-field"); if (tokenField) { tokenField.value = ""; } src_DI.tokenStore.clearToken(); } function injectGlobalFunctions() { gmUtils.unsafeWindow.gmUtils = gmUtils; gmUtils.unsafeWindow.gosvonDI = src_DI; gmUtils.unsafeWindow.openSettingsModal = openSettingsModal; gmUtils.unsafeWindow.closeSettingsModal = closeSettingsModal; gmUtils.unsafeWindow.setCustomTypeColor = setCustomTypeColor; gmUtils.unsafeWindow.removeCustomTypeColor = removeCustomTypeColor; gmUtils.unsafeWindow.setIsFansTableViewEnabled = setIsFansTableViewEnabled; gmUtils.unsafeWindow.setIsRepliesCollectingEnabled = setIsRepliesCollectingEnabled; gmUtils.unsafeWindow.changeBotFilterEnabledState = changeBotFilterEnabledState; gmUtils.unsafeWindow.fetchUserRegistrationDate = fetchUserRegistrationDate; gmUtils.unsafeWindow.openAdvancedUserInfoModal = openAdvancedUserInfoModal; gmUtils.unsafeWindow.checkToken = checkToken; gmUtils.unsafeWindow.toggleTokenShow = toggleTokenShow; gmUtils.unsafeWindow.clearToken = clearToken; } function createLayoutFromString(template, vars = {}) { const html = Object.entries(vars).reduce(((acc, [key, value]) => acc.replace(new RegExp(`{{${key}}}`, "g"), value)), template); const div = document.createElement("div"); div.innerHTML = html; return div.children[0]; } function injectAdvancedUserInfoModal() { const modalEl = createLayoutFromString(`\n <div\n class="gosvon-advanced-menu-modal"\n style="\n pointer-events: none;\n opacity: 0;\n "\n >\n <div class="gosvon-advanced-menu-modal-clickout-listener"></div>\n\n <div class="gosvon-advanced-menu-modal-content">\n <div class="gosvon-advanced-menu-modal-content-mount"></div>\n <div\n class="gosvon-advanced-menu-modal-close"\n aria-label="Закрыть"\n tabindex="0"\n role="button"\n >\n <svg width="24" height="24" viewBox="0 0 24 24" xmlns="https://www.w3.org/2000/svg">\n <g id="cancel_24__Page-2" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">\n <g id="cancel_24__cancel_24">\n <path d="M0 0h24v24H0z"></path>\n <path d="M18.3 5.7a.99.99 0 00-1.4 0L12 10.6 7.1 5.7a.99.99 0 00-1.4 1.4l4.9 4.9-4.9 4.9a.99.99 0 001.4 1.4l4.9-4.9 4.9 4.9a.99.99 0 001.4-1.4L13.4 12l4.9-4.9a.99.99 0 000-1.4z" id="cancel_24__Mask" fill="currentColor">\n </path>\n </g>\n </g>\n </svg>\n </div>\n </div>\n </div>\n `); const contentMountEl = modalEl.querySelector(".gosvon-advanced-menu-modal-content-mount"); const iframeEl = createLayoutFromString(`\n <iframe\n src="${"MISSING_ENV_VAR".ADVANCED_MENU_IFRAME_SRC || `${src_DI.host}/script/AdvMenu/`}"\n width="100%"\n height="100%"\n frameBorder="0"\n class="\n gosvon-menu-wrapper\n "\n ></iframe>\n `); const permissionDeniedEl = createLayoutFromString(`\n <div class="gosvon-advanced-menu-modal-permissions-denied">\n <div class="gosvon-advanced-menu-modal-permissions-denied-title-wrap">\n <div class="gosvon-advanced-menu-modal-permissions-denied-title">\n Ловушка Повара — Инспектор\n </div>\n </div>\n <div class="gosvon-advanced-menu-modal-permissions-denied-description">\n Чтобы открыть <a target="_blank" href="${src_DI.host}/help/#inspector">инспектор</a>, необходимо иметь код и специальный уровень доступа, которые вы можете получить через нашего бота в Телеграме: <a target="_blank" href="https://t.me/GosvonBot/">t.me/GosvonBot</a>.\n <br><br>\n Код необходимо ввести <a class="gosvon-advanced-menu-modal-settings-link">в настройках скрипта</a>.\n </div>\n </div>\n `); document.body.appendChild(modalEl); src_DI.advancedMenuStore.saveModalElement(iframeEl); const clickoutListenerEl = modalEl.querySelector(".gosvon-advanced-menu-modal-clickout-listener"); const closeBtnEL = modalEl.querySelector(".gosvon-advanced-menu-modal-close"); function close() { modalEl.style.pointerEvents = "none"; modalEl.style.opacity = "0"; } clickoutListenerEl?.addEventListener("click", close); closeBtnEL?.addEventListener("click", close); const settingsLinkEl = permissionDeniedEl.querySelector(".gosvon-advanced-menu-modal-settings-link"); settingsLinkEl?.addEventListener("click", (() => { close(); openSettingsModal(); })); src_DI.tokenStore.onStateUpdate((({permissions}) => { if (!contentMountEl || !iframeEl || !permissionDeniedEl) { return; } if (permissions.includes(ETokenPermissions.CAN_OPEN_ADVANCED_MENU)) { permissionDeniedEl.remove(); contentMountEl.appendChild(iframeEl); } else { iframeEl.remove(); contentMountEl.appendChild(permissionDeniedEl); } })); } function injectNotifications() { if (!src_DI.config.state.message) { return; } const lastClosedNotificationUnix = gmUtils.getStorageValue("gosvonLastClosedNotificationUnix") || 0; if (lastClosedNotificationUnix && lastClosedNotificationUnix >= src_DI.config.state.message.unix) { return; } const notificationsEl = createLayoutFromString(`\n <div class="gosvon-notification">\n <div class="gosvon-notification-logo">\n Скрипт подсветки Ловушка Повара\n </div>\n\n <div class="gosvon-notification-close">×</div>\n\n <div class="gosvon-notification-title">\n ${src_DI.config.state.message.header}\n </div>\n\n <div class="gosvon-notification-text">\n ${src_DI.config.state.message.text}\n </div>\n </div>\n `); const closeBtn = notificationsEl.querySelector(".gosvon-notification-close"); const close = () => { notificationsEl?.remove(); gmUtils.setStorageValue("gosvonLastClosedNotificationUnix", src_DI.config.state.message?.unix); }; closeBtn?.addEventListener("click", close); setTimeout(close, 6e4); document.body.appendChild(notificationsEl); } // EXTERNAL MODULE: ../../node_modules/.pnpm/@[email protected]/node_modules/@mdi/svg/svg/information.svg var information = __webpack_require__(41); var information_default = __webpack_require__.n(information); // EXTERNAL MODULE: ../../node_modules/.pnpm/@[email protected]/node_modules/@mdi/svg/svg/eye-outline.svg var eye_outline = __webpack_require__(531); var eye_outline_default = __webpack_require__.n(eye_outline); function isMobile() { return !!document.location.host.match("m.vk.com"); } function getMarksIdsUniquePrefixes() { return [ ...new Set(src_DI.config.state.marks.map((markItem => markItem.id.substring(0, 2)))) ]; } function splitMarksToGroups() { const marksIdsUniquePrefixes = getMarksIdsUniquePrefixes(); return marksIdsUniquePrefixes.map((idPrefixItem => src_DI.config.state.marks.filter((markItem => markItem.id.substring(0, 2) === idPrefixItem)))); } function createMarksCheckboxes() { const marksGroups = splitMarksToGroups(); const botCountsByMarkId = src_DI.botCounter.state.marks; return marksGroups.reduce(((groupsAcc, marks, marksGroupIndex) => { const marksGroupCheckboxes = marks.reduce(((acc, mark) => { const isEnabled = !src_DI.userSettings.checkIsMarkDisabled(mark.id); return `\n ${acc}\n <label class="gosvon-mb-10 gosvon-checkbox">\n <input\n type="checkbox"\n ${isEnabled ? "checked" : ""}\n onchange="changeBotFilterEnabledState('${mark.id}', this, 'mark')"\n />\n <div class="gosvon-checkbox-view"></div>\n <div>\n ${mark.name} (${botCountsByMarkId[mark.id]})\n </div>\n </label>\n `; }), ""); return `\n ${groupsAcc}\n <div\n ${marksGroupIndex > 0 ? 'class="gosvon-mt-40"' : ""}\n >\n ${marksGroupCheckboxes}\n </div>\n `; }), ""); } function createTypesCheckboxes() { return src_DI.config.state.types.reduce(((acc, type) => { const isEnabled = !src_DI.userSettings.checkIsTypeDisabled(type.id); const customUserColor = src_DI.userSettings.getCustomTypeColor(type.id); const botCountsByTypeId = src_DI.botCounter.state.types; return `\n ${acc}\n <div class="gosvon-type-checkbox">\n <label class="gosvon-checkbox">\n <input\n type="checkbox"\n ${isEnabled ? "checked" : ""}\n ${!type.switchable ? "disabled" : ""}\n onchange="changeBotFilterEnabledState('${type.id}', this, 'type')"\n />\n <div class="gosvon-checkbox-view"></div>\n <div class="gosvon-type-name">\n ${type.name} (${botCountsByTypeId[type.id]})\n </div>\n </label>\n\n <label>\n <input\n id="botTypeColorInput_${type.id}"\n type="color"\n value="${customUserColor || type.serverColor}"\n oninput="setCustomTypeColor(${type.id}, this.value)"\n class="gosvon-type-color"\n />\n </label>\n\n <button\n class="gosvon-reset-color-btn"\n onclick="\n removeCustomTypeColor(${type.id})\n document.getElementById('botTypeColorInput_${type.id}').value = '${type.serverColor}'\n "\n >\n ×\n </button>\n </div>\n `; }), ""); } function injectSettingsModal() { const modalEl = createLayoutFromString(`\n <div\n class="\n gosvon-settings-modal\n ${isMobile() ? "gosvon-settings-modal-mobile" : ""}\n gosvon-js-settings-modal\n "\n style="display: none;"\n >\n <div class="gosvon-settings-container">\n <div class="gosvon-settings-modal-title-wrap">\n <div\n class="gosvon-settings-modal-close"\n aria-label="Закрыть"\n tabindex="0"\n role="button"\n onclick="closeSettingsModal()"\n >\n <svg width="24" height="24" viewBox="0 0 24 24" xmlns="https://www.w3.org/2000/svg">\n <g id="cancel_24__Page-2" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">\n <g id="cancel_24__cancel_24">\n <path id="cancel_24__Bounds" d="M0 0h24v24H0z">\n </path>\n <path d="M18.3 5.7a.99.99 0 00-1.4 0L12 10.6 7.1 5.7a.99.99 0 00-1.4 1.4l4.9 4.9-4.9 4.9a.99.99 0 001.4 1.4l4.9-4.9 4.9 4.9a.99.99 0 001.4-1.4L13.4 12l4.9-4.9a.99.99 0 000-1.4z" id="cancel_24__Mask" fill="currentColor">\n </path>\n </g>\n </g>\n </svg>\n </div>\n\n <div class="gosvon-settings-modal-title">\n Ловушка Повара — Настройки\n </div>\n </div>\n\n <div class="gosvon-settings-content">\n <div class="gosvon-token-field-wrapper">\n <div class="gosvon-token-line">\n <div class="gosvon-token-form-line">\n <div class="gosvon-token-input-line">\n <form>\n <input\n placeholder="Код доступа"\n type="text"\n type="password"\n value="${src_DI.tokenStore.state.userToken || ""}"\n class="gosvon-token-field"\n />\n </form>\n <button\n class="gosvon-token-show-btn gosvon-token-btn"\n onclick="toggleTokenShow()"\n >\n ${eye_outline_default()}\n </button>\n <button\n class="gosvon-token-clear-btn gosvon-token-btn"\n onclick="clearToken()"\n >\n ×\n </button>\n </div>\n\n <button\n class="gosvon-token-check-btn"\n onclick="checkToken()"\n >\n Установить код\n </button>\n </div>\n\n <div class="gosvon-token-info"></div>\n </div>\n\n <div class="gosvon-token-error"></div>\n\n <div class="gosvon-token-description">\n Код доступа вы можете получить через нашего бота в телеграме\n <a target="_blank" href="https://t.me/GosvonBot/">t.me/GosvonBot</a>.\n Дополнительные уровни доступа можно получить при подписке\n на регулярную поддержку проекта,\n а также другими способами\n </div>\n </div>\n\n <div class="gosvon-flex gosvon-mb-30">\n\n <div class="gosvon-settings-modal-hidden-mobile gosvon-w-full gosvon-mr-20">\n <label class="gosvon-checkbox">\n <input\n type="checkbox"\n ${src_DI.userSettings.state.isFansTableViewEnabled ? "checked" : ""}\n onchange="setIsFansTableViewEnabled(this)"\n />\n\n <div class="gosvon-checkbox-view"></div>\n\n <div>\n Табличный вид лайков в окне\n </div>\n </label>\n </div>\n\n <div class="gosvon-w-full">\n <label class="gosvon-checkbox">\n <input\n type="checkbox"\n class="gosvon-js-replies-collecting-checkbox"\n ${!src_DI.tokenStore.state.userToken ? "disabled" : ""}\n ${src_DI.userSettings.state.isRepliesCollectingEnabled && !src_DI.tokenStore.state.userToken ? "checked" : ""}\n onchange="setIsRepliesCollectingEnabled(this)"\n />\n\n <div class="gosvon-checkbox-view gosvon-js-replies-collecting-checkbox-view"></div>\n\n <div>\n Сбор и отправка комментаторов\n </div>\n\n <a\n class="gosvon-replies-collecting-description"\n target="_blank"\n href="${src_DI.host}/help/#replies-collecting"\n >\n ${information_default()}\n </a>\n </label>\n </div>\n\n </div>\n\n <div class="gosvon-settings-modal-checkboxes">\n\n <div class="gosvon-settings-modal-types">\n\n ${createTypesCheckboxes()}\n\n </div>\n\n <div class="gosvon-settings-modal-marks">\n\n ${createMarksCheckboxes()}\n\n </div>\n </div>\n </div>\n </div>\n </div>\n `); const tokenField = modalEl.querySelector(".gosvon-token-field"); const checkTokenBtnEl = modalEl.querySelector(".gosvon-token-check-btn"); const checkTokenErrorEl = modalEl.querySelector(".gosvon-token-error"); const checkTokenInfoEl = modalEl.querySelector(".gosvon-token-info"); const repliesCollectingCheckbox = modalEl.querySelector(".gosvon-js-replies-collecting-checkbox"); const repliesCollectingCheckboxView = modalEl.querySelector(".gosvon-js-replies-collecting-checkbox-view"); src_DI.tokenStore.onStateUpdate((({isTokenCheckingInProgress, errorMessage, expires, tokenLevel, tokenPoints, isTokenShown}) => { if (!checkTokenBtnEl || !checkTokenErrorEl || !checkTokenInfoEl || !tokenField || !repliesCollectingCheckbox) { return; } tokenField.type = isTokenShown ? "text" : "password"; checkTokenBtnEl.disabled = isTokenCheckingInProgress; checkTokenErrorEl.innerText = errorMessage || ""; checkTokenInfoEl.innerHTML = ""; if (expires !== null && typeof tokenLevel !== undefined) { if (tokenLevel == null) { tokenLevel = 0; } repliesCollectingCheckbox.disabled = false; const showPoints = tokenPoints && tokenPoints > 0 ? `, очки: ${tokenPoints}` : ""; checkTokenInfoEl.innerHTML = `\n Уровень доступа: ${tokenLevel}${showPoints}\n <br />\n До: ${formatDate(expires)}\n `; } else { repliesCollectingCheckbox.disabled = true; } })); src_DI.userSettings.onStateUpdate((({isRepliesCollectingEnabled, isRepliesCollectingEnabledAutomatically}) => { if (!repliesCollectingCheckbox || !repliesCollectingCheckboxView) { return; } repliesCollectingCheckbox.checked = isRepliesCollectingEnabled; if (isRepliesCollectingEnabledAutomatically) { repliesCollectingCheckboxView.classList.add("gosvon-replies-collecting-enabled-automatically"); } })); document.body.appendChild(modalEl); } function injectLayout() { injectSettingsModal(); injectAdvancedUserInfoModal(); injectNotifications(); } const povar = ""; function addMobileSettingsModalOpener() { const existingMenuItems = [ ...document.querySelectorAll(".SettingsMenu__item") ]; const firstExistingMenuItem = existingMenuItems[0]; firstExistingMenuItem.before(createLayoutFromString(`\n <a\n class="SettingsMenu__item Row"\n href="#"\n onclick="\n event.preventDefault();\n openSettingsModal();\n "\n >\n <div class="Row__in">\n <div class="SettingsMenu__itemIcon">\n <div aria-hidden="true" class="svgIcon svgIcon-user_outline_28">\n <img src="${povar}" />\n </div>\n </div>\n\n <div class="SettingsMenu__itemTitle">\n GosVon\n </div>\n </div>\n </a>\n `)); } function addDesktopSettingsModalOpenerForGuestUser() { const headerNavAudio = document.querySelector(".HeaderNav__audio"); headerNavAudio?.setAttribute("style", "min-width: auto !important;"); const topRegLink = document.querySelector("#top_reg_link"); topRegLink?.before(createLayoutFromString(`\n <a\n class="top_nav_link"\n onclick="openSettingsModal()"\n >\n <img\n src="${povar}"\n width="20"\n height="20"\n style="vertical-align: middle; margin: -0.25em 0.25em auto auto;"\n />\n\n <span>\n GosVon\n </span>\n </a>\n `)); } function addDesktopSettingsModalOpenerForGuestUserMobile() { const topRegLink = document.querySelector(".UnauthorizedHeader__logo"); topRegLink?.before(createLayoutFromString(`\n <a\n class="top_nav_link"\n onclick="openSettingsModal()"\n >\n <img\n src="${povar}"\n width="30"\n height="30"\n />\n\n <span\n style="vertical-align: super; margin-right: 15px;"\n >\n Меню\n </span>\n </a>\n `)); } function addDesktopSettingsModalOpenerForLoggedInUser() { const existingMenuItems = [ ...document.querySelectorAll(".top_profile_mrow") ]; const lastExistingMenuItem = existingMenuItems[existingMenuItems.length - 2]; lastExistingMenuItem.after(createLayoutFromString(`\n <a\n class="top_profile_mrow"\n onclick="TopMenu.select(this, event); openSettingsModal();"\n >\n <div class="menu_item_icon">\n <img\n src="${povar}"\n width="20"\n height="20"\n />\n </div>\n\n <span>\n GosVon\n </span>\n </a>\n `)); } // EXTERNAL MODULE: ../../node_modules/.pnpm/@[email protected]/node_modules/@mdi/svg/svg/list-box-outline.svg var list_box_outline = __webpack_require__(455); var list_box_outline_default = __webpack_require__.n(list_box_outline); // EXTERNAL MODULE: ../../node_modules/.pnpm/@[email protected]/node_modules/@mdi/svg/svg/account-box-outline.svg var account_box_outline = __webpack_require__(797); var account_box_outline_default = __webpack_require__.n(account_box_outline); // EXTERNAL MODULE: ../../node_modules/.pnpm/@[email protected]/node_modules/@mdi/svg/svg/calendar-month-outline.svg var calendar_month_outline = __webpack_require__(287); var calendar_month_outline_default = __webpack_require__.n(calendar_month_outline); // EXTERNAL MODULE: ../../node_modules/.pnpm/@[email protected]/node_modules/@mdi/svg/svg/information-slab-box-outline.svg var information_slab_box_outline = __webpack_require__(656); var information_slab_box_outline_default = __webpack_require__.n(information_slab_box_outline); function findBot(idOrNickname) { const matchId = String(idOrNickname).match(/^(id)?(\d{3,})$/)?.[2]; const id = matchId && Number(matchId); let foundBot = null; if (id) { foundBot = src_DI.botList.find((bot => bot.id === id)); } else { foundBot = src_DI.botList.find((bot => bot.nickname === idOrNickname)); } if (!foundBot) { return null; } if (foundBot.mark && src_DI.userSettings.checkIsMarkDisabled(foundBot.mark.id)) { return null; } if (src_DI.userSettings.checkIsTypeDisabled(foundBot.type.id)) { return null; } return foundBot; } function generateRandomString() { let randomString = ""; for (let i = 0; i < 10; i += 1) { randomString += Math.floor(Math.random() * 10); } return randomString; } function highlightReplyFromBot({replyEl, bot, authorLinkEl}) { const botMarkChip = createLayoutFromString(`\n <i class="gosvon-reply-mark-or-type">\n (${bot.mark?.name || bot.type.name})\n </i>\n `); const replyContent = replyEl.querySelector(".reply_content"); if (!replyContent) { console.error("GosVon. Ошибка 42"); return; } replyContent.classList.add("gosvon-reply-content-from-bot"); authorLinkEl.after(botMarkChip); src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { replyContent.style.background = customUserColor || bot.type.serverColor; })); } function findParentBySelector(el, selector) { let found = null; while (el) { if (el.matches(selector)) { found = el; break; } el = el.parentElement; } return found; } function saveReply(replyEl, userId, replyLink) { if (!src_DI.userSettings.state.isRepliesCollectingEnabled) { console.log("GosVon: Сбор комментариев отключен в настройках"); return; } const matched = replyLink.match(/https:\/\/vk.com\/wall(-?\d+)_(\d+)\?reply=(\d+)/); if (!matched) { return; } const [, wallId, postId, replyId] = matched; const postEl = findParentBySelector(replyEl, ".post"); if (!postEl) { return; } const repliesBtnEl = postEl?.querySelector("[data-like-button-type=comment]"); const repliesCountAttr = repliesBtnEl?.getAttribute("data-count"); const repliesCount = Number(repliesCountAttr); const authorLinkEl = postEl.querySelector('a[data-post-click-type="post_owner_link"]'); const wallSlug = authorLinkEl?.getAttribute("href")?.slice(1); src_DI.replyCollector.add({ wallId, postId, replyId, userId, wallSlug, repliesCount }); } function createReplyButton({icon, title, onclick = "", href = "#"}) { const isDefaultHref = href === "#"; const wrapper = createLayoutFromString(`\n <a\n class="gosvon-reply-action"\n href="${href}"\n ${isDefaultHref ? "" : 'target="blank"'}\n data-title="${title}"\n onclick="${onclick}"\n onmouseover="\n showTitle(this, undefined, undefined, {noZIndex: true});\n "\n >\n ${icon}\n </a>\n `); return wrapper; } function onReplyFound(replyEl) { const authorLinkEl = replyEl.querySelector("a.author"); const userID = authorLinkEl?.getAttribute("data-from-id"); const replyAuthorEl = replyEl.querySelector(".reply_author"); const lastActionLinkEL = replyEl.querySelector(".reply_link_wrap:last-child"); const replyLink = replyEl.querySelector(".wd_lnk")?.getAttribute("href"); const replyFooter = replyEl.querySelector(".reply_footer"); const authorAvatarLink = replyEl.querySelector(".AvatarRich__img")?.src; const authorName = authorLinkEl?.innerText; if (!authorLinkEl || !userID || !replyAuthorEl || !authorName || !replyLink) { return; } const isReplyFromGroupAccount = userID.startsWith("-"); if (isReplyFromGroupAccount) { return; } saveReply(replyEl, userID, replyLink); const actionsEl = createLayoutFromString(`\n <div class="gosvon-reply-actions">\n </div>\n `); const bot = findBot(userID); if (bot) { highlightReplyFromBot({ replyEl, bot, authorLinkEl }); if (bot.type.shouldShowActions) { const commentsButtonEl = createReplyButton({ icon: list_box_outline_default(), title: "Комментарии", href: `${src_DI.host}/?usr=${userID}` }); actionsEl.appendChild(commentsButtonEl); const cardButtonEl = createReplyButton({ icon: account_box_outline_default(), title: "Карточка", href: `${src_DI.host}/photo.php?id=${userID}&rand=${generateRandomString()}` }); actionsEl.appendChild(cardButtonEl); } } const advancedMenuButtonEl = createReplyButton({ icon: information_slab_box_outline_default(), title: "Инспектор", onclick: `\n openAdvancedUserInfoModal('${userID}', '${replyLink}', '${authorName}', '${authorAvatarLink}');\n return false;\n ` }); actionsEl.appendChild(advancedMenuButtonEl); const registrationDateButtonEl = createReplyButton({ icon: calendar_month_outline_default(), title: "Дата регистрации", onclick: `\n fetchUserRegistrationDate('${userID}');\n return false;\n ` }); actionsEl.appendChild(registrationDateButtonEl); if (lastActionLinkEL) { lastActionLinkEL.after(actionsEl); } else if (replyFooter) { replyFooter.append(actionsEl); } const registrationDateEl = createLayoutFromString(`\n <div></div>\n `); replyAuthorEl.append(registrationDateEl); src_DI.registrationDates.onChangeRegistrationDate(userID, (registrationDate => { registrationDateEl.innerText = registrationDate || ""; if (registrationDate) { registrationDateButtonEl.remove(); } })); } // EXTERNAL MODULE: ../../node_modules/.pnpm/@[email protected]/node_modules/@mdi/svg/svg/account-arrow-left-outline.svg var account_arrow_left_outline = __webpack_require__(377); var account_arrow_left_outline_default = __webpack_require__.n(account_arrow_left_outline); function getIdFromReply(replyEl) { const authorLinkEl = replyEl.querySelector("a.author"); const userID = authorLinkEl?.getAttribute("data-from-id") || undefined; return userID; } function findIdOfAuthorOfParentReply(formEl) { const potentialReply = formEl?.parentElement?.parentElement?.parentElement?.parentElement?.previousElementSibling; if (!potentialReply?.classList.contains("reply")) { return undefined; } return getIdFromReply(potentialReply); } function findIdOfAuthorFromTitle(formEl) { const replyId = formEl.querySelector(".reply_to_mem")?.getAttribute("onclick")?.match(/wall\.showReply\(this, '(.*)', '(.*)'/)?.[2]; const replyEl = document.querySelector(`#post${replyId}`); if (!replyEl) { return undefined; } return getIdFromReply(replyEl); } function getWhoIReplyToId(formEl) { return findIdOfAuthorFromTitle(formEl) || findIdOfAuthorOfParentReply(formEl); } function onReplyFormFound(formEl) { const replyToEl = formEl.querySelector('input[type="hidden"]'); const buttonsWrapperEl = formEl.querySelector(".reply_field_wrap"); const fieldEl = formEl.querySelector(".submit_post_field"); if (!replyToEl || !buttonsWrapperEl || !fieldEl) { return; } const attachBotAccountBtn = createLayoutFromString(`\n <button\n class="gosvon-reply-form-btn"\n style="\n display: none;\n "\n data-title="Вы отвечаете боту, добавить его карточку?"\n onmouseover="\n showTitle(this, undefined, undefined, {noZIndex: true});\n "\n >\n ${account_arrow_left_outline_default()}\n </button>\n `); buttonsWrapperEl.append(attachBotAccountBtn); let bot = null; const sleep = () => new Promise((resolve => { setTimeout(resolve); })); attachBotAccountBtn.addEventListener("click", (async () => { if (!bot) { return; } attachBotAccountBtn.style.display = "none"; const cardLink = `${src_DI.host}/photo.php?id=${bot.id}&rand=${generateRandomString()}`; const event = new ClipboardEvent("paste", { clipboardData: new DataTransfer }); event.clipboardData.setData("text/plain", ` ${cardLink} `); fieldEl.dispatchEvent(event); await sleep(); [ ...fieldEl.childNodes ].forEach((node => { if (node.nodeValue) { node.nodeValue = node.nodeValue.replace(cardLink, "").replace(" ", ""); } })); fieldEl.focus(); await sleep(); const range = document.createRange(); const selection = window.getSelection(); const textNode = fieldEl.childNodes[fieldEl.childNodes.length - 1]; range.setStart(textNode, textNode.length); range.setEnd(textNode, textNode.length); selection?.removeAllRanges(); selection?.addRange(range); })); let interval = -1; let prevUserID = ""; const init = () => { if (!document.body.contains(formEl)) { clearInterval(interval); return; } const userID = getWhoIReplyToId(formEl); if (!userID || userID === prevUserID) { return; } prevUserID = userID; bot = findBot(userID); if (!bot) { attachBotAccountBtn.style.display = "none"; return; } attachBotAccountBtn.style.display = "block"; }; init(); interval = setInterval(init, 500); } function onNewDesignPostFound(postEl) { const fullPostId = postEl?.getAttribute("data-post-id"); const [authorId, postId] = fullPostId?.split("_") ?? []; const postHeaderEl = postEl.querySelector(".PostHeader"); const postHeaderTitleEl = postEl.querySelector(".PostHeaderTitle"); const postFromAuthorEl = postEl.querySelector(".PostHeaderSubtitle > .PostHeaderSubtitle__item"); const postFromAuthorId = postFromAuthorEl?.getAttribute("href")?.match(/vk.com\/(.+)/)?.[1]; if (!authorId || !postId || !postHeaderTitleEl || !postHeaderEl) { return; } const checkId = postFromAuthorId || authorId; const bot = findBot(checkId); if (bot) { postHeaderEl.classList.add("gosvon-post-header"); const botMarkChip = createLayoutFromString(`\n <i class="gosvon-reply-mark-or-type">\n (${bot.mark?.name || bot.type.name})\n </i>\n `); const gosvonLinks = createLayoutFromString(`\n <span>\n ${botMarkChip.outerHTML}\n\n ${bot.type.shouldShowActions ? `\n <a target='_blank' href='${src_DI.host}/?usr=${bot.id}'>\n Комментарии\n </a>\n\n <a target='_blank' href='${src_DI.host}/photo.php?id=${bot.id}&rand=${generateRandomString()}'>\n Карточка\n </a>\n ` : ""}\n </span>\n `); if (postFromAuthorEl) { postFromAuthorEl.parentElement?.after(gosvonLinks); } else { postHeaderTitleEl.append(gosvonLinks); } src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { postHeaderEl.style.background = customUserColor || bot.type.serverColor; })); } } function onOldDesignPostFound(postEl) { const authorLinkEl = postEl.querySelector('a[data-post-click-type="post_owner_link"]'); const authorId = authorLinkEl?.getAttribute("data-from-id"); const postAuthorLineEl = postEl.querySelector(".PostHeader .post_author"); const postHeaderEl = postEl.querySelector(".PostHeader"); if (!authorLinkEl || !authorId || !postAuthorLineEl || !postHeaderEl) { return; } const bot = findBot(authorId); if (bot) { postHeaderEl.classList.add("gosvon-post-header"); const gosvonLine = createLayoutFromString(`\n <div class="gosvon-post-line-old-design"></div>\n `); const botMarkChip = createLayoutFromString(`\n <i class="gosvon-reply-mark-or-type">\n (${bot.mark?.name || bot.type.name})\n </i>\n `); const gosvonLinks = createLayoutFromString(`\n <i>\n ${botMarkChip.outerHTML}\n\n <a target='_blank' href='${src_DI.host}/?usr=${authorId}'>\n Комментарии\n </a>\n <a target='_blank' href='${src_DI.host}/photo.php?id=${authorId}&rand=${generateRandomString()}'>\n Карточка\n </a>\n </i>\n `); if (bot.type.shouldShowActions) { gosvonLine.append(gosvonLinks); } authorLinkEl.after(gosvonLine); src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { postHeaderEl.style.background = customUserColor || bot.type.serverColor; })); } } function onPostFound(postEl) { if (postEl.classList.contains("Post--redesign")) { onNewDesignPostFound(postEl); } else { onOldDesignPostFound(postEl); } } function hightlightFan(fanEl) { const userID = fanEl.getAttribute("data-id"); if (!userID) { return; } const bot = findBot(userID); if (!bot) { return; } const highlightOverlayEl = createLayoutFromString(`\n <div class="gosvon-highlight-overlay"></div>\n `); fanEl.append(highlightOverlayEl); fanEl.style.position = "relative"; src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { highlightOverlayEl.style.background = customUserColor || bot.type.serverColor; })); const markEl = createLayoutFromString(`\n <div\n class="gosvon-desktop-fan"\n style="\n background: ${src_DI.userSettings.getCustomTypeColor(bot.type.id) || bot.type.serverColor};\n "\n >\n (${bot.mark?.name || bot.type.name})\n </div>\n `); fanEl.appendChild(markEl); if (bot.type.shouldShowActions) { fanEl.append(createLayoutFromString(`\n <center>\n <i>\n <a target='_blank' href='${src_DI.host}/?usr=${userID}'>\n Комм.\n </a>\n <a target='_blank' href='${src_DI.host}/photo.php?id=${userID}&rand=${generateRandomString()}'>\n Карт.\n </a>\n </i>\n </center>\n `)); } } const TABLE_CLASS = "gosvon-fan-table"; function getOrCreateTable(fanEl) { let table = document.querySelector(`.${TABLE_CLASS}`); if (table) { return table; } const rows = document.querySelector(".fans_rows"); if (rows) { rows.style.display = "none"; } table = createLayoutFromString(`<table class="${TABLE_CLASS}"></table>`); fanEl.parentElement?.before(table); return table; } function pasteIntoTable(fanEl) { const table = getOrCreateTable(fanEl); const userID = fanEl.getAttribute("data-id"); const linkEl = fanEl.querySelector(".fans_fan_lnk"); const name = linkEl?.innerText; const pageLink = linkEl?.href || ""; const imageSrc = fanEl.querySelector(".fans_fan_img")?.src; const bot = findBot(userID || ""); const row = createLayoutFromString(`\n <table>\n <tbody>\n <tr>\n <td class="gosvon-mono">\n WILL BE REPLACED TO INDEX\n </td>\n\n <td class="gosvon-mono gosvon-tac">\n ${userID}\n </td>\n\n <td\n colspan="${bot ? 0 : 3}"\n >\n <div class="gosvon-name">\n <div class="gosvon-avatar">\n <img\n src="${imageSrc}"\n height="20"\n />\n </div>\n\n <a\n href="${pageLink}"\n target="_blank"\n >\n ${name}\n </a>\n </div>\n </td>\n\n ${bot ? `\n <td\n class="gosvon-tac"\n style="\n background: ${src_DI.userSettings.getCustomTypeColor(bot.type.id) || bot.type.serverColor};\n "\n >\n ${bot.mark?.name || bot.type.name || ""}\n </td>\n\n <td class="gosvon-tac">\n ${bot.type.shouldShowActions ? `\n <a target='_blank' href='${src_DI.host}/?usr=${userID}'>\n Комментарии\n </a>\n\n <a target='_blank' href='${src_DI.host}/photo.php?id=${userID}&rand=${generateRandomString()}'>\n Карточка\n </a>\n ` : ""}\n </td>\n ` : ""}\n </tr>\n </tbody>\n </table>\n `).children[0].children[0]; const rowWithIdLessThanCurrent = [ ...table.children ].find((rowEl => { const rowId = Number(rowEl.children[1]?.innerHTML.replace(/\D/g, "")); return rowId < Number(userID); })); if (rowWithIdLessThanCurrent) { rowWithIdLessThanCurrent.before(row); } else { table.append(row); } [ ...table.children ].forEach(((rowEl, index) => { rowEl.children[0].innerHTML = `${index + 1}.`; })); } function onFanFound(fanEl) { if (src_DI.userSettings.state.isFansTableViewEnabled) { pasteIntoTable(fanEl); } else { hightlightFan(fanEl); } } function onLikeFound(likeEl) { const userID = likeEl.getAttribute("href").substring(1); const bot = findBot(userID); if (!bot) { return; } const userAvatarEl = likeEl.querySelector(".like_tt_image"); if (!userAvatarEl) { return; } userAvatarEl.style.opacity = "0.5"; const highlightOverlayEl = createLayoutFromString(`\n <div class="gosvon-highlight-overlay"></div>\n `); likeEl.style.position = "relative"; likeEl.append(highlightOverlayEl); src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { likeEl.style.background = customUserColor || bot.type.serverColor; })); } function onProfileFound(pageNameEl) { const idOrNickname = (() => { const splits = location.href.split("/"); return splits[splits.length - 1]; })(); if (!idOrNickname) { return; } src_DI.registrationDates.fetchRegistrationDate(idOrNickname).then((registrationDate => { pageNameEl?.after(createLayoutFromString(`\n <div class="gosvon-profile-registration-date">\n ${registrationDate}\n </div>\n `)); })); const bot = findBot(idOrNickname); if (bot) { const gosvonLine = createLayoutFromString(`\n <div class="gosvon-profile-line"></div>\n `); const botMarkChip = createLayoutFromString(`\n <i class="gosvon-mark-chip">\n (${bot.mark?.name || bot.type.name})\n </i>\n `); const gosvonLinks = createLayoutFromString(`\n <i>\n <a target='_blank' href='${src_DI.host}/?usr=${idOrNickname}'>\n Комментарии\n </a>\n <a target='_blank' href='${src_DI.host}/photo.php?id=${idOrNickname}&rand=${generateRandomString()}'>\n Карточка\n </a>\n </i>\n `); gosvonLine.append(botMarkChip); if (bot.type.shouldShowActions) { gosvonLine.append(gosvonLinks); } pageNameEl.after(gosvonLine); src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { botMarkChip.style.background = customUserColor || bot.type.serverColor; })); } } function onFoundMobilePost(mobilePostEl) { const wiHeadLink = mobilePostEl.querySelector(".wi_head a"); const postHeaderEl = mobilePostEl.querySelector(".wi_head"); const postDateContentWrapperEl = mobilePostEl.querySelector(".wi_info"); const userID = wiHeadLink?.getAttribute("href")?.match(/\/(.+)\?/)?.[1]; const areaPostFromAuthorEl = mobilePostEl.querySelector(".pi_signed"); const postFromAuthorEl = areaPostFromAuthorEl?.querySelector(".user"); const postFromAuthorId = postFromAuthorEl?.getAttribute("href")?.substring(1); if (!userID || !postHeaderEl || !postDateContentWrapperEl) { return; } const checkId = postFromAuthorId || userID; const bot = findBot(checkId); if (!bot) { return; } const selectedHighlightArea = areaPostFromAuthorEl || postHeaderEl; selectedHighlightArea.classList.add("gosvon-post-mobile-header"); const gosvonLinks = createLayoutFromString(`\n <div>\n <i class="gosvon-reply-mark-or-type">\n (${bot.mark?.name || bot.type.name})\n </i>\n\n ${bot.type.shouldShowActions ? `\n <a target='_blank' href='${src_DI.host}/?usr=${bot.id}'>\n Комментарии\n </a>\n\n <a target='_blank' href='${src_DI.host}/photo.php?id=${bot.id}&rand=${generateRandomString()}'>\n Карточка\n </a>\n ` : ""}\n </div>\n `); if (postFromAuthorEl) { postFromAuthorEl.after(gosvonLinks); } else { postDateContentWrapperEl.append(gosvonLinks); } src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { selectedHighlightArea.style.background = customUserColor || bot.type.serverColor; })); } async function onFoundMobileProfile() { const idOrNickname = document.location.pathname.substring(1); const nameEl = document.querySelector(".ProfileInfoName"); if (!nameEl) { return; } src_DI.registrationDates.fetchRegistrationDate(idOrNickname).then((registrationDate => { nameEl?.after(createLayoutFromString(`\n <div class="gosvon-profile-registration-date">\n ${registrationDate}\n </div>\n `)); })); const bot = findBot(idOrNickname); if (!bot) { return; } const gosvonLine = createLayoutFromString(`\n <div class="gosvon-mt-10 gosvon-mb-10"></div>\n `); const botMarkChip = createLayoutFromString(`\n <i class="gosvon-mark-chip">\n (${bot.mark?.name || bot.type.name})\n </i>\n `); const gosvonLinks = createLayoutFromString(`\n <center>\n <div class="gosvon-chip-placeholder"></div>\n\n ${bot.type.shouldShowActions ? `\n <a target='_blank' href='${src_DI.host}/?usr=${bot.id}'>\n Комментарии\n </a>\n\n <a target='_blank' href='${src_DI.host}/photo.php?id=${bot.id}&rand=${generateRandomString()}'>\n Карточка\n </a>\n ` : ""}\n </center>\n `); const chipPlaceholderEl = gosvonLinks.querySelector(".gosvon-chip-placeholder"); chipPlaceholderEl?.replaceWith(botMarkChip); gosvonLine.append(gosvonLinks); nameEl.after(gosvonLine); src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { botMarkChip.style.background = customUserColor || bot.type.serverColor; })); } function removeIdPrefix(userIdOrNickName) { return userIdOrNickName.match(/^(id)\d+$/) ? userIdOrNickName.replace(/^id/, "") : userIdOrNickName; } function getAbsolutePath(relativePath) { const link = document.createElement("img"); link.src = relativePath; return link.src; } function saveReply_saveReply(userId, replyLink) { if (!src_DI.userSettings.state.isRepliesCollectingEnabled) { console.log("GosVon: Сбор комментариев отключен в настройках"); return; } const matched = replyLink.match(/vk.com\/wall(-?\d+)_(\d+)\?reply=(\d+)/); if (!matched) { return; } const [, wallId, postId, replyId] = matched; const postLinkEl = document.querySelector(".wi_head a"); if (!postLinkEl) { return; } const wallSlug = postLinkEl?.getAttribute("href")?.slice(1).split("?")[0]; src_DI.replyCollector.add({ wallId, postId, replyId, userId, wallSlug, repliesCount: 0 }); } function onFoundMobileReply(replyEl) { const replyUserNameEl = replyEl.querySelector(".ReplyItem__name"); const replyLinkObject = replyEl.querySelector(".item_date"); const replyLink = replyLinkObject?.getAttribute("href"); const authorAvatarLink = replyEl.querySelector(".Avatar__image")?.style.backgroundImage.match(/url[(]'(.+)'[)]/); const authorName = replyUserNameEl?.innerText; const highlightArea = replyEl.querySelector(".ReplyItem__content"); if (!replyUserNameEl || !highlightArea || !replyLink) { return; } const userID = removeIdPrefix(replyUserNameEl.getAttribute("href").substring(1)); const isReplyFromGroupAccount = userID.startsWith("-"); if (isReplyFromGroupAccount) { return; } saveReply_saveReply(userID, replyLink); const registrationDateEl = createLayoutFromString(`\n <div class="gosvon-reg-date"></div>\n `); replyUserNameEl.after(registrationDateEl); src_DI.registrationDates.onChangeRegistrationDate(userID, (registrationDate => { registrationDateEl.innerText = registrationDate || ""; })); const bot = findBot(userID); const actionsEl = createLayoutFromString(`\n <div class="gosvon-reply-mobile-actions">\n </div>\n `); const authorAvatarLinkResolved = authorAvatarLink?.[1] ? getAbsolutePath(authorAvatarLink[1]) : "https://vk.com/images/camera_50.png"; if (bot) { const gosvonLinks = createLayoutFromString(`\n <div class="gosvon-mobile-reply-line">\n <i class="gosvon-reply-mark-or-type">\n (${bot.mark?.name || bot.type.name})\n </i>\n </div>\n `); replyUserNameEl.after(gosvonLinks); src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { highlightArea.style.background = customUserColor || bot.type.serverColor; highlightArea.classList.add("gosvon-reply-content-from-bot"); })); if (bot.type.shouldShowActions) { const commentsButtonEl = createLayoutFromString(`\n <a\n class="gosvon-reply-mobile-action"\n href="${src_DI.host}/?usr=${userID}"\n target="blank"\n >\n ${list_box_outline_default()}\n </a>\n `); actionsEl.appendChild(commentsButtonEl); const cardButtonEl = createLayoutFromString(`\n <a\n class="gosvon-reply-mobile-action"\n href="${src_DI.host}/photo.php?id=${userID}&rand=${generateRandomString()}"\n target="blank"\n >\n ${account_box_outline_default()}\n </a>\n `); actionsEl.appendChild(cardButtonEl); } } const advancedMenuButtonEl = createLayoutFromString(`\n <a\n class="gosvon-reply-mobile-action"\n href="#"\n onclick="\n openAdvancedUserInfoModal('${userID}', '${replyLink}', '${authorName}', '${authorAvatarLinkResolved}');\n return false;"\n >\n ${information_slab_box_outline_default()}\n </a>\n `); actionsEl.appendChild(advancedMenuButtonEl); const registrationDateButtonEl = createLayoutFromString(`\n <a\n class="gosvon-reply-mobile-action"\n href="#"\n onclick="\n fetchUserRegistrationDate('${userID}');\n return false;"\n >\n ${calendar_month_outline_default()}\n </a>\n `); actionsEl.appendChild(registrationDateButtonEl); replyLinkObject?.after(actionsEl); src_DI.registrationDates.onChangeRegistrationDate(userID, (registrationDate => { registrationDateEl.innerText = registrationDate || ""; if (registrationDate) { registrationDateButtonEl.remove(); } })); } function onFoundMobileFan(fanEl) { const userID = fanEl.getAttribute("href")?.substring(1); if (!userID) { return; } const bot = findBot(userID); if (!bot) { return; } const highlightOverlayEl = createLayoutFromString(`\n <div class="gosvon-highlight-overlay"></div>\n `); fanEl.append(highlightOverlayEl); fanEl.style.position = "relative"; src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { highlightOverlayEl.style.background = customUserColor || bot.type.serverColor; })); if (bot.type.shouldShowActions) { fanEl.appendChild(createLayoutFromString(`\n <i>\n <a\n target="_blank"\n onclick="event.stopPropagation();"\n href="${src_DI.host}/?usr=${userID}"\n >\n Комментарии\n </a>\n <a\n target="_blank"\n onclick="event.stopPropagation();"\n href="${src_DI.host}/photo.php?id=${userID}&rand=${generateRandomString()}"\n >\n Карточка\n </a>\n </i>\n `)); } fanEl.appendChild(createLayoutFromString(`\n <div class="gosvon-fan-mark-or-type">\n (${bot.mark?.name || bot.type.name})\n </div>\n `)); } function onMentionTTFound(mentionEl) { const mentionTTName = mentionEl.querySelector(".mention_tt_name"); if (!mentionTTName) { return; } const userID = mentionTTName.getAttribute("href").substring(1); const bot = findBot(userID); if (!bot) { return; } const mentionTTTitle = mentionEl.querySelector(".mention_tt_title"); if (!mentionTTTitle) { return; } src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { mentionTTTitle.style.background = customUserColor || bot.type.serverColor; })); const markEl = createLayoutFromString(`\n <i>\n (${bot.mark?.name || bot.type.name})\n </i>\n `); mentionTTTitle.after(markEl); markEl.after(createLayoutFromString(`\n <i>\n <a target='_blank' href='${src_DI.host}/?usr=${userID}'>\n Комментарии\n </a>\n <a target='_blank' href='${src_DI.host}/photo.php?id=${userID}&rand=${generateRandomString()}'>\n Карточка\n </a>\n </i>\n `)); } function elementsFinderFactory() { const mapSelectorHandlers = {}; let alreadyFoundElements = []; setInterval((() => { Object.entries(mapSelectorHandlers).forEach((([selector, handlers]) => { const newFoundElements = [ ...document.querySelectorAll(selector) ].filter((element => !alreadyFoundElements.includes(element))); newFoundElements.forEach((element => { handlers.forEach((handler => { handler(element); })); })); alreadyFoundElements = [ ...alreadyFoundElements, ...newFoundElements ]; })); }), 300); function on(selector, foundHandler) { if (!mapSelectorHandlers[selector]) { mapSelectorHandlers[selector] = []; } mapSelectorHandlers[selector].push(foundHandler); } return { on }; } function onFriendFound(friendEl) { const rawUserID = friendEl.getAttribute("id")?.match(/row(\d+)/)?.[1] ?? ""; const userID = rawUserID ? Number(rawUserID) : null; const titleEl = friendEl.querySelector(".friends_field_title"); if (!userID || !titleEl) { return; } const bot = findBot(userID); if (bot) { const gosvonLine = createLayoutFromString(`\n <div class='friends_field'></div>\n `); const botMarkChip = createLayoutFromString(`\n <i class="gosvon-reply-mark-or-type">\n (${bot.mark?.name || bot.type.name})\n </i>\n `); gosvonLine.append(botMarkChip); if (bot.type.shouldShowActions) { const gosvonLinks = createLayoutFromString(`\n <span>\n <a target='_blank' href='${src_DI.host}/?usr=${userID}'>\n Комментарии\n </a>\n <a target='_blank' href='${src_DI.host}/photo.php?id=${userID}&rand=${generateRandomString()}'>\n Карточка\n </a>\n </span>\n `); gosvonLine.append(gosvonLinks); } titleEl.after(gosvonLine); src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { friendEl.style.background = customUserColor || bot.type.serverColor; })); } } function onFriendMobileFound(friendEl) { const linkUserIdEl = friendEl.querySelector(".Friends__itemBody > a"); const rawUserID = linkUserIdEl?.getAttribute("class")?.match(/unew(\d+)/)?.[1] ?? ""; const userID = Number.parseInt(rawUserID, 10); if (!Number.isFinite(userID)) { return; } const bot = findBot(userID); if (bot) { const gosvonLine = createLayoutFromString(`\n <div class='gosvon-reply-mobile-actions'></div>\n `); const botMarkChip = createLayoutFromString(`\n <i class="gosvon-mobile-friend-mark-or-type">\n (${bot.mark?.name || bot.type.name})\n </i>\n `); gosvonLine.append(botMarkChip); if (bot.type.shouldShowActions) { const commentsButtonEl = createLayoutFromString(`\n <a\n class="gosvon-reply-mobile-friend_action"\n href="${src_DI.host}/?usr=${userID}"\n target="blank"\n >\n ${list_box_outline_default()}\n </a>\n `); gosvonLine.append(commentsButtonEl); const cardButtonEl = createLayoutFromString(`\n <a\n class="gosvon-reply-mobile-friend_action"\n href="${src_DI.host}/photo.php?id=${userID}&rand=${generateRandomString()}"\n target="blank"\n >\n ${account_box_outline_default()}\n </a>\n `); gosvonLine.append(cardButtonEl); } linkUserIdEl?.append(gosvonLine); src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { friendEl.style.background = customUserColor || bot.type.serverColor; })); } } function onRepostFound_onNewDesignPostFound(postEl) { const fullPostId = postEl.querySelector(".published_by_date")?.getAttribute("href"); const [authorId, postId] = fullPostId?.match(/(-?\d+_\d+)/)?.[0]?.split("_") ?? []; const postHeaderEl = postEl.querySelector(".copy_post_header"); const postHeaderTitleEl = postEl.querySelector(".copy_post_author"); const postSignedEl = postEl.querySelector(".wall_signed"); const postSignedAuthorEl = postEl.querySelector(".wall_signed_by"); const postSignedAuthorID = postSignedAuthorEl?.getAttribute("mention_id")?.match(/id(\d+)/)?.[0]; if (!authorId || !postId || !postHeaderTitleEl || !postHeaderEl) { return; } const bot = postSignedAuthorID ? findBot(postSignedAuthorID) : findBot(authorId); if (bot) { if (!postSignedAuthorEl) { postHeaderEl.classList.add("gosvon-post-header"); } const botMarkChip = createLayoutFromString(`\n <i class="gosvon-reply-mark-or-type">\n (${bot.mark?.name || bot.type.name})\n </i>\n `); const gosvonLinks = createLayoutFromString(`\n <span>\n ${botMarkChip.outerHTML}\n\n ${bot.type.shouldShowActions ? `\n <a target='_blank' href='${src_DI.host}/?usr=${bot.id}'>\n Комментарии\n </a>\n\n <a target='_blank' href='${src_DI.host}/photo.php?id=${bot.id}&rand=${generateRandomString()}'>\n Карточка\n </a>\n ` : ""}\n </span>\n `); if (postSignedEl) { postSignedEl.append(gosvonLinks); } else { postHeaderTitleEl.append(gosvonLinks); } src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { if (postSignedEl) { postSignedEl.style.background = customUserColor || bot.type.serverColor; } else { postHeaderEl.style.background = customUserColor || bot.type.serverColor; } })); } } function onFoundMobileRepost(mobilePostEl) { const wiHeadLink = mobilePostEl.querySelector(".pic_header a"); const postHeaderEl = mobilePostEl.querySelector(".pic_header"); const postHeaderDate = mobilePostEl.querySelector(".pic_desc"); const userID = wiHeadLink?.getAttribute("class")?.match(/new(\d+)/)?.[1]; if (!userID || !postHeaderEl || !postHeaderDate) { return; } const bot = findBot(userID); if (!bot) { return; } postHeaderEl.classList.add("gosvon-post-mobile-header"); const gosvonLinks = createLayoutFromString(`\n <div>\n <i class="gosvon-reply-mark-or-type">\n (${bot.mark?.name || bot.type.name})\n </i>\n\n ${bot.type.shouldShowActions ? `\n <a target='_blank' href='${src_DI.host}/?usr=${bot.id}'>\n Комментарии\n </a>\n\n <a target='_blank' href='${src_DI.host}/photo.php?id=${bot.id}&rand=${generateRandomString()}'>\n Карточка\n </a>\n ` : ""}\n </div>\n `); postHeaderDate.append(gosvonLinks); src_DI.userSettings.onChangeCustomColor(bot.type.id, (customUserColor => { postHeaderEl.style.background = customUserColor || bot.type.serverColor; })); } // EXTERNAL MODULE: ../../node_modules/.pnpm/[email protected][email protected]/node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js var injectStylesIntoStyleTag = __webpack_require__(886); var injectStylesIntoStyleTag_default = __webpack_require__.n(injectStylesIntoStyleTag); // EXTERNAL MODULE: ../../node_modules/.pnpm/[email protected][email protected]/node_modules/style-loader/dist/runtime/styleDomAPI.js var styleDomAPI = __webpack_require__(788); var styleDomAPI_default = __webpack_require__.n(styleDomAPI); // EXTERNAL MODULE: ../../node_modules/.pnpm/[email protected][email protected]/node_modules/style-loader/dist/runtime/insertBySelector.js var insertBySelector = __webpack_require__(122); var insertBySelector_default = __webpack_require__.n(insertBySelector); // EXTERNAL MODULE: ../../node_modules/.pnpm/[email protected][email protected]/node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js var setAttributesWithoutAttributes = __webpack_require__(791); var setAttributesWithoutAttributes_default = __webpack_require__.n(setAttributesWithoutAttributes); // EXTERNAL MODULE: ../../node_modules/.pnpm/[email protected][email protected]/node_modules/style-loader/dist/runtime/insertStyleElement.js var insertStyleElement = __webpack_require__(611); var insertStyleElement_default = __webpack_require__.n(insertStyleElement); // EXTERNAL MODULE: ../../node_modules/.pnpm/[email protected][email protected]/node_modules/style-loader/dist/runtime/styleTagTransform.js var styleTagTransform = __webpack_require__(671); var styleTagTransform_default = __webpack_require__.n(styleTagTransform); // EXTERNAL MODULE: ../../node_modules/.pnpm/[email protected][email protected]/node_modules/css-loader/dist/cjs.js!../../node_modules/.pnpm/[email protected][email protected][email protected]/node_modules/sass-loader/dist/cjs.js!./src/style.scss var style = __webpack_require__(397); var options = {}; options.styleTagTransform = styleTagTransform_default(); options.setAttributes = setAttributesWithoutAttributes_default(); options.insert = insertBySelector_default().bind(null, "head"); options.domAPI = styleDomAPI_default(); options.insertStyleElement = insertStyleElement_default(); var update = injectStylesIntoStyleTag_default()(style.Z, options); const src_style = style.Z && style.Z.locals ? style.Z.locals : undefined; async function start() { const DI = await getDIReady(); injectGlobalFunctions(); if (document.readyState !== "loading") { injectLayout(); } else { document.addEventListener("DOMContentLoaded", injectLayout); } console.log("GosVon: Разметка внедрена"); Object.values(DI).forEach((it => { it.onLayoutInjected?.(); })); const finder = elementsFinderFactory(); finder.on("#top_profile_menu", addDesktopSettingsModalOpenerForLoggedInUser); finder.on("#top_reg_link", addDesktopSettingsModalOpenerForGuestUser); finder.on(".UnauthorizedHeader__logo", addDesktopSettingsModalOpenerForGuestUserMobile); finder.on(".SettingsMenu", addMobileSettingsModalOpener); finder.on(".reply_form", onReplyFormFound); finder.on(".reply", onReplyFound); finder.on(".post", onPostFound); finder.on(".wl_post", onPostFound); finder.on(".fans_fan_row", onFanFound); finder.on(".like_tt_owner", onLikeFound); finder.on(".OwnerPageName", onProfileFound); finder.on(".mention_tt", onMentionTTFound); finder.on(".copy_quote", onRepostFound_onNewDesignPostFound); finder.on(".wall_item", onFoundMobilePost); finder.on(".ProfileInfo__in", onFoundMobileProfile); finder.on(".ReplyItem", onFoundMobileReply); finder.on(".pcont .inline_item", onFoundMobileFan); finder.on(".pic_body_wrap", onFoundMobileRepost); finder.on(".friends_user_row", onFriendFound); finder.on(".Friends__item", onFriendMobileFound); } start(); })(); })();
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址