// ==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();
})();
})();