Files
vk-mute/extension/dist/dom.js

974 lines
80 KiB
JavaScript

/******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/
/******/ // Check if module is in cache
/******/ if(installedModules[moduleId]) {
/******/ return installedModules[moduleId].exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ i: moduleId,
/******/ l: false,
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Flag the module as loaded
/******/ module.l = true;
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/******/
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/
/******/ // define getter function for harmony exports
/******/ __webpack_require__.d = function(exports, name, getter) {
/******/ if(!__webpack_require__.o(exports, name)) {
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
/******/ }
/******/ };
/******/
/******/ // define __esModule on exports
/******/ __webpack_require__.r = function(exports) {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/
/******/ // create a fake namespace object
/******/ // mode & 1: value is a module id, require it
/******/ // mode & 2: merge all properties of value into the ns
/******/ // mode & 4: return value when already ns object
/******/ // mode & 8|1: behave like require
/******/ __webpack_require__.t = function(value, mode) {
/******/ if(mode & 1) value = __webpack_require__(value);
/******/ if(mode & 8) return value;
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
/******/ var ns = Object.create(null);
/******/ __webpack_require__.r(ns);
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
/******/ return ns;
/******/ };
/******/
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = function(module) {
/******/ var getter = module && module.__esModule ?
/******/ function getDefault() { return module['default']; } :
/******/ function getModuleExports() { return module; };
/******/ __webpack_require__.d(getter, 'a', getter);
/******/ return getter;
/******/ };
/******/
/******/ // Object.prototype.hasOwnProperty.call
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "";
/******/
/******/
/******/ // Load entry module and return exports
/******/ return __webpack_require__(__webpack_require__.s = "./src/dom/main.js");
/******/ })
/************************************************************************/
/******/ ({
/***/ "./node_modules/css-loader/dist/cjs.js!./src/dom/dom.css":
/*!***************************************************************!*\
!*** ./node_modules/css-loader/dist/cjs.js!./src/dom/dom.css ***!
\***************************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
// Imports
var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");
exports = ___CSS_LOADER_API_IMPORT___(false);
// Module
exports.push([module.i, ".mute_message .mutetooltip {\r\n visibility: hidden;\r\n width: 120px;\r\n background-color: #555;\r\n color: #fff;\r\n text-align: center;\r\n padding: 5px 0;\r\n border-radius: 6px;\r\n \r\n /* Position the tooltip text */\r\n position: absolute;\r\n z-index: 1;\r\n bottom: 110%;\r\n margin-left: -53px;\r\n \r\n /* Fade in tooltip */\r\n opacity: 0;\r\n transition: opacity 0.3s;\r\n}\r\n\r\n/* Tooltip arrow */\r\n.mute_message .mutetooltip::after {\r\n content: \"\";\r\n position: absolute;\r\n top: 100%;\r\n left: 50%;\r\n margin-left: -5px;\r\n border-width: 5px;\r\n border-style: solid;\r\n border-color: #555 transparent transparent transparent;\r\n}\r\n\r\n/* Show the tooltip text when you mouse over the tooltip container */\r\n.mute_message:hover .mutetooltip {\r\n visibility: visible;\r\n opacity: 1;\r\n}\r\n\r\n.mute_message {\r\n margin-top: .46rem;\r\n margin-left: 4px;\r\n margin-right: 3px;\r\n display: inline-block;\r\n vertical-align: top;\r\n width: 12px;\r\n height: 12px;\r\n background-size: contain !important;\r\n}\r\n\r\n.im-mess--actions {\r\n margin-right: -30px !important;\r\n}", ""]);
// Exports
module.exports = exports;
/***/ }),
/***/ "./node_modules/css-loader/dist/runtime/api.js":
/*!*****************************************************!*\
!*** ./node_modules/css-loader/dist/runtime/api.js ***!
\*****************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
/*
MIT License http://www.opensource.org/licenses/mit-license.php
Author Tobias Koppers @sokra
*/
// css base code, injected by the css-loader
// eslint-disable-next-line func-names
module.exports = function (useSourceMap) {
var list = []; // return the list of modules as css string
list.toString = function toString() {
return this.map(function (item) {
var content = cssWithMappingToString(item, useSourceMap);
if (item[2]) {
return "@media ".concat(item[2], " {").concat(content, "}");
}
return content;
}).join('');
}; // import a list of modules into the list
// eslint-disable-next-line func-names
list.i = function (modules, mediaQuery, dedupe) {
if (typeof modules === 'string') {
// eslint-disable-next-line no-param-reassign
modules = [[null, modules, '']];
}
var alreadyImportedModules = {};
if (dedupe) {
for (var i = 0; i < this.length; i++) {
// eslint-disable-next-line prefer-destructuring
var id = this[i][0];
if (id != null) {
alreadyImportedModules[id] = true;
}
}
}
for (var _i = 0; _i < modules.length; _i++) {
var item = [].concat(modules[_i]);
if (dedupe && alreadyImportedModules[item[0]]) {
// eslint-disable-next-line no-continue
continue;
}
if (mediaQuery) {
if (!item[2]) {
item[2] = mediaQuery;
} else {
item[2] = "".concat(mediaQuery, " and ").concat(item[2]);
}
}
list.push(item);
}
};
return list;
};
function cssWithMappingToString(item, useSourceMap) {
var content = item[1] || ''; // eslint-disable-next-line prefer-destructuring
var cssMapping = item[3];
if (!cssMapping) {
return content;
}
if (useSourceMap && typeof btoa === 'function') {
var sourceMapping = toComment(cssMapping);
var sourceURLs = cssMapping.sources.map(function (source) {
return "/*# sourceURL=".concat(cssMapping.sourceRoot || '').concat(source, " */");
});
return [content].concat(sourceURLs).concat([sourceMapping]).join('\n');
}
return [content].join('\n');
} // Adapted from convert-source-map (MIT)
function toComment(sourceMap) {
// eslint-disable-next-line no-undef
var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap))));
var data = "sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(base64);
return "/*# ".concat(data, " */");
}
/***/ }),
/***/ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js":
/*!****************************************************************************!*\
!*** ./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js ***!
\****************************************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var isOldIE = function isOldIE() {
var memo;
return function memorize() {
if (typeof memo === 'undefined') {
// Test for IE <= 9 as proposed by Browserhacks
// @see http://browserhacks.com/#hack-e71d8692f65334173fee715c222cb805
// Tests for existence of standard globals is to allow style-loader
// to operate correctly into non-standard environments
// @see https://github.com/webpack-contrib/style-loader/issues/177
memo = Boolean(window && document && document.all && !window.atob);
}
return memo;
};
}();
var getTarget = function getTarget() {
var memo = {};
return function memorize(target) {
if (typeof memo[target] === 'undefined') {
var styleTarget = document.querySelector(target); // Special case to return head of iframe instead of iframe itself
if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {
try {
// This will throw an exception if access to iframe is blocked
// due to cross-origin restrictions
styleTarget = styleTarget.contentDocument.head;
} catch (e) {
// istanbul ignore next
styleTarget = null;
}
}
memo[target] = styleTarget;
}
return memo[target];
};
}();
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 index = getIndexByIdentifier(identifier);
var obj = {
css: item[1],
media: item[2],
sourceMap: item[3]
};
if (index !== -1) {
stylesInDom[index].references++;
stylesInDom[index].updater(obj);
} else {
stylesInDom.push({
identifier: identifier,
updater: addStyle(obj, options),
references: 1
});
}
identifiers.push(identifier);
}
return identifiers;
}
function insertStyleElement(options) {
var style = document.createElement('style');
var attributes = options.attributes || {};
if (typeof attributes.nonce === 'undefined') {
var nonce = true ? __webpack_require__.nc : undefined;
if (nonce) {
attributes.nonce = nonce;
}
}
Object.keys(attributes).forEach(function (key) {
style.setAttribute(key, attributes[key]);
});
if (typeof options.insert === 'function') {
options.insert(style);
} else {
var target = getTarget(options.insert || 'head');
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);
}
return style;
}
function removeStyleElement(style) {
// istanbul ignore if
if (style.parentNode === null) {
return false;
}
style.parentNode.removeChild(style);
}
/* istanbul ignore next */
var replaceText = function replaceText() {
var textStore = [];
return function replace(index, replacement) {
textStore[index] = replacement;
return textStore.filter(Boolean).join('\n');
};
}();
function applyToSingletonTag(style, index, remove, obj) {
var css = remove ? '' : obj.media ? "@media ".concat(obj.media, " {").concat(obj.css, "}") : obj.css; // For old IE
/* istanbul ignore if */
if (style.styleSheet) {
style.styleSheet.cssText = replaceText(index, css);
} else {
var cssNode = document.createTextNode(css);
var childNodes = style.childNodes;
if (childNodes[index]) {
style.removeChild(childNodes[index]);
}
if (childNodes.length) {
style.insertBefore(cssNode, childNodes[index]);
} else {
style.appendChild(cssNode);
}
}
}
function applyToTag(style, options, obj) {
var css = obj.css;
var media = obj.media;
var sourceMap = obj.sourceMap;
if (media) {
style.setAttribute('media', media);
} else {
style.removeAttribute('media');
}
if (sourceMap && btoa) {
css += "\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), " */");
} // For old IE
/* istanbul ignore if */
if (style.styleSheet) {
style.styleSheet.cssText = css;
} else {
while (style.firstChild) {
style.removeChild(style.firstChild);
}
style.appendChild(document.createTextNode(css));
}
}
var singleton = null;
var singletonCounter = 0;
function addStyle(obj, options) {
var style;
var update;
var remove;
if (options.singleton) {
var styleIndex = singletonCounter++;
style = singleton || (singleton = insertStyleElement(options));
update = applyToSingletonTag.bind(null, style, styleIndex, false);
remove = applyToSingletonTag.bind(null, style, styleIndex, true);
} else {
style = insertStyleElement(options);
update = applyToTag.bind(null, style, options);
remove = function remove() {
removeStyleElement(style);
};
}
update(obj);
return function updateStyle(newObj) {
if (newObj) {
if (newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap) {
return;
}
update(obj = newObj);
} else {
remove();
}
};
}
module.exports = function (list, options) {
options = options || {}; // Force single-tag solution on IE6-9, which has a hard limit on the # of <style>
// tags it will allow on a page
if (!options.singleton && typeof options.singleton !== 'boolean') {
options.singleton = isOldIE();
}
list = list || [];
var lastIdentifiers = modulesToDom(list, options);
return function update(newList) {
newList = newList || [];
if (Object.prototype.toString.call(newList) !== '[object Array]') {
return;
}
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;
};
};
/***/ }),
/***/ "./src/dom/controls.js":
/*!*****************************!*\
!*** ./src/dom/controls.js ***!
\*****************************/
/*! exports provided: tryToAddControls, hideExistingMessages, createTryToInitInterval, tryToInitControls */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "tryToAddControls", function() { return tryToAddControls; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "hideExistingMessages", function() { return hideExistingMessages; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "createTryToInitInterval", function() { return createTryToInitInterval; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "tryToInitControls", function() { return tryToInitControls; });
/* harmony import */ var _utils_getChatBody__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/getChatBody */ "./src/utils/getChatBody.js");
function _createForOfIteratorHelper(o) { if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (o = _unsupportedIterableToArray(o))) { var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var it, normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(n); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
/**
*
* @param id {String}
* @return {HTMLSpanElement}
*/
function muteBtnHTML(id) {
var element = document.createElement('span');
element.setAttribute('class', 'mute_message');
element.setAttribute('id', "mute".concat(id));
element.style.background = "url(".concat(chrome.runtime.getURL("assets/mute.png"), ") center no-repeat");
element.innerHTML = '<span class="mutetooltip">Заглушить</span>';
return element;
}
function tryToAddControls(target) {
if (target.className === 'im-mess--check fl_l') {
var message = target.parentElement;
addControlButton(message);
}
}
/**
* Create mute button and inset it to the actionArea
* @param actionArea {HTMLElement}
* @param senderId {String}
* @return {HTMLElement}
*/
function addMuteButton(actionArea, senderId) {
var muteButton = muteBtnHTML(senderId);
actionArea.appendChild(muteButton);
muteButton.style.display = "none";
return muteButton;
}
/**
* Add event listeners to the actionArea
* @param actionsArea {HTMLElement}
*/
function addActionAreaEvents(actionsArea) {
actionsArea.parentElement.addEventListener("mouseenter", function (event) {
event.target.getElementsByClassName("mute_message")[0].style.display = "inline-block";
});
actionsArea.parentElement.addEventListener("mouseleave", function (event) {
event.target.getElementsByClassName("mute_message")[0].style.display = "none";
});
}
/**
*
* @return {function(...[]=)}
*/
function setIdToHideHandle() {
return function (event) {
var clickedId = event.target.id.substr(4); // get id of sender from element id
var clickedName = event.target.parentElement.parentElement.parentElement.parentElement;
clickedName = clickedName.children[0].children[0].children[0].innerText;
chrome.storage.sync.get('idsToHide', function (data) {
var idsToHide = data.idsToHide || [];
if (idsToHide.filter(function (user) {
return user.id == clickedId;
}).length === 0) {
idsToHide.push({
id: clickedId,
name: clickedName
});
chrome.storage.sync.set({
idsToHide: idsToHide
}, function () {
chrome.storage.sync.get('isExtensionOn', function (data) {
if (data.isExtensionOn) {
hideExistingMessages();
}
});
});
}
});
};
}
function hideExistingMessages() {
chrome.storage.sync.get('idsToHide', function (data) {
var chatBody = Object(_utils_getChatBody__WEBPACK_IMPORTED_MODULE_0__["getChatBody"])();
var _iterator = _createForOfIteratorHelper(chatBody.children),
_step;
try {
var _loop = function _loop() {
var item = _step.value;
if (data.idsToHide.filter(function (user) {
return user.id == item.dataset.peer;
}).length > 0) {
item.style.display = "none";
}
};
for (_iterator.s(); !(_step = _iterator.n()).done;) {
_loop();
}
} catch (err) {
_iterator.e(err);
} finally {
_iterator.f();
}
});
} // Try to add controls until successful. Needed for page refresh.
function createTryToInitInterval() {
var controlsInterval = setInterval(function () {
if (!tryToInitControls(controlsInterval)) {
clearInterval(controlsInterval);
}
}, 200);
return controlsInterval;
}
/**
*
* @param message {HTMLElement}
*/
function addControlButton(message) {
var actionsArea = message.getElementsByClassName("im-mess--actions")[0];
if (actionsArea && actionsArea.lastChild.className !== "mute_message") {
var senderId = message.parentElement.parentElement.parentElement["dataset"].peer;
var muteBtn = addMuteButton(actionsArea, senderId);
addActionAreaEvents(actionsArea);
muteBtn.addEventListener("click", setIdToHideHandle());
return true;
} else {
return false;
}
}
function tryToInitControls() {
var status = true;
var chatBody = Object(_utils_getChatBody__WEBPACK_IMPORTED_MODULE_0__["getChatBody"])();
if (!chatBody) return false;
var _iterator2 = _createForOfIteratorHelper(chatBody.children),
_step2;
try {
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
var item = _step2.value;
if (item.className.includes('im-mess-stack _im_mess_stack')) {
var messages = item.children[1].children[1].getElementsByClassName('im-mess _im_mess');
var _iterator3 = _createForOfIteratorHelper(messages),
_step3;
try {
for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
var message = _step3.value;
status = addControlButton(message, chatBody);
}
} catch (err) {
_iterator3.e(err);
} finally {
_iterator3.f();
}
}
}
} catch (err) {
_iterator2.e(err);
} finally {
_iterator2.f();
}
return status;
}
/***/ }),
/***/ "./src/dom/dom.css":
/*!*************************!*\
!*** ./src/dom/dom.css ***!
\*************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
var api = __webpack_require__(/*! ../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");
var content = __webpack_require__(/*! !../../node_modules/css-loader/dist/cjs.js!./dom.css */ "./node_modules/css-loader/dist/cjs.js!./src/dom/dom.css");
content = content.__esModule ? content.default : content;
if (typeof content === 'string') {
content = [[module.i, content, '']];
}
var options = {};
options.insert = "head";
options.singleton = false;
var update = api(content, options);
var exported = content.locals ? content.locals : {};
module.exports = exported;
/***/ }),
/***/ "./src/dom/hide_element.js":
/*!*********************************!*\
!*** ./src/dom/hide_element.js ***!
\*********************************/
/*! exports provided: addNewMessageEventListener, returnMessagesEventListener */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addNewMessageEventListener", function() { return addNewMessageEventListener; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "returnMessagesEventListener", function() { return returnMessagesEventListener; });
/* harmony import */ var _utils_getChatBody__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/getChatBody */ "./src/utils/getChatBody.js");
/* harmony import */ var _controls__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./controls */ "./src/dom/controls.js");
function _createForOfIteratorHelper(o) { if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (o = _unsupportedIterableToArray(o))) { var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var it, normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(n); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
function addNewMessageEventListener() {
var chatBody = Object(_utils_getChatBody__WEBPACK_IMPORTED_MODULE_0__["getChatBody"])();
chatBody.addEventListener('DOMNodeInserted', function (event) {
newMessageHandler(event.target);
});
}
function newMessageHandler(message) {
Object(_controls__WEBPACK_IMPORTED_MODULE_1__["tryToAddControls"])(message);
if (message.className === 'im-mess-stack _im_mess_stack ') {
chrome.storage.sync.get('isExtensionOn', function (data) {
if (data.isExtensionOn) {
chrome.storage.sync.get('idsToHide', function (data) {
if (data.idsToHide.filter(function (user) {
return user.id == message.dataset.peer;
}).length > 0) {
message.style.display = "none";
}
});
}
});
}
}
function returnMessagesEventListener() {
chrome.storage.onChanged.addListener(function (changes) {
var isExtensionOn = changes.isExtensionOn;
var idsToHide = changes.idsToHide;
var chatBody = Object(_utils_getChatBody__WEBPACK_IMPORTED_MODULE_0__["getChatBody"])();
if (isExtensionOn) {
if (isExtensionOn.newValue === false) {
var _iterator = _createForOfIteratorHelper(chatBody.children),
_step;
try {
for (_iterator.s(); !(_step = _iterator.n()).done;) {
var item = _step.value;
item.style.display = "block";
}
} catch (err) {
_iterator.e(err);
} finally {
_iterator.f();
}
} else {
Object(_controls__WEBPACK_IMPORTED_MODULE_1__["hideExistingMessages"])();
}
}
if (idsToHide) {
chrome.storage.sync.get('isExtensionOn', function (data) {
if (data.isExtensionOn) {
if (idsToHide.newValue.length < idsToHide.oldValue.length) {
// for (let item of chatBody.children) {
// item.style.display = "block";
// }
// hideExistingMessages();
var _iterator2 = _createForOfIteratorHelper(chatBody.children),
_step2;
try {
var _loop = function _loop() {
var item = _step2.value;
if (idsToHide.newValue.filter(function (user) {
return user.id == item.dataset.peer;
}).length === 0) {
item.style.display = "block";
}
};
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
_loop();
}
} catch (err) {
_iterator2.e(err);
} finally {
_iterator2.f();
}
}
}
});
}
});
}
/***/ }),
/***/ "./src/dom/main.js":
/*!*************************!*\
!*** ./src/dom/main.js ***!
\*************************/
/*! no exports provided */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var _dom_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./dom.css */ "./src/dom/dom.css");
/* harmony import */ var _dom_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_dom_css__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _controls__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./controls */ "./src/dom/controls.js");
/* harmony import */ var _utils_Url__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/Url */ "./src/utils/Url.js");
/* harmony import */ var _hide_element__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./hide_element */ "./src/dom/hide_element.js");
function init() {
var url = new _utils_Url__WEBPACK_IMPORTED_MODULE_2__["UrlController"]();
url.onChange(function () {
if (Object(_controls__WEBPACK_IMPORTED_MODULE_1__["tryToInitControls"])()) {
Object(_controls__WEBPACK_IMPORTED_MODULE_1__["createTryToInitInterval"])();
Object(_hide_element__WEBPACK_IMPORTED_MODULE_3__["addNewMessageEventListener"])();
Object(_hide_element__WEBPACK_IMPORTED_MODULE_3__["returnMessagesEventListener"])();
Object(_controls__WEBPACK_IMPORTED_MODULE_1__["hideExistingMessages"])();
}
});
}
init();
/***/ }),
/***/ "./src/utils/Url.js":
/*!**************************!*\
!*** ./src/utils/Url.js ***!
\**************************/
/*! exports provided: UrlController */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UrlController", function() { return UrlController; });
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
var INTERVAL_TIME = 100;
var UrlController = /*#__PURE__*/function () {
function UrlController() {
_classCallCheck(this, UrlController);
this._changeListeners = [];
this._interval = null;
this._url = window.location.href;
}
_createClass(UrlController, [{
key: "onChange",
value: function onChange(cb) {
this._changeListeners.push(cb);
if (this._interval === null) {
this._createInterval();
}
}
}, {
key: "removeEventListener",
value: function removeEventListener(cb) {
this._changeListeners = this._changeListeners.filter(function (item) {
return item !== cb;
});
if (this._changeListeners.length === 0) {
this._clearInterval();
}
}
}, {
key: "_intervalTick",
value: function _intervalTick() {
var currentUrl = window.location.href;
if (currentUrl !== this.url) {
this._broadcast(this.url, currentUrl);
this.url = currentUrl;
}
}
}, {
key: "_broadcast",
value: function _broadcast(oldUrl, newUrl) {
this._changeListeners.forEach(function (cb) {
return cb(oldUrl, newUrl);
});
}
}, {
key: "_createInterval",
value: function _createInterval() {
var _this = this;
this.interval = setInterval(function () {
return _this._intervalTick();
}, INTERVAL_TIME);
}
}, {
key: "_clearInterval",
value: function _clearInterval() {
clearInterval(this.interval);
this.interval = null;
}
}]);
return UrlController;
}();
/***/ }),
/***/ "./src/utils/getChatBody.js":
/*!**********************************!*\
!*** ./src/utils/getChatBody.js ***!
\**********************************/
/*! exports provided: getChatBody */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getChatBody", function() { return getChatBody; });
function getChatBody() {
return document.getElementsByClassName("_im_peer_history im-page-chat-contain")[0];
}
/***/ })
/******/ });
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./src/dom/dom.css","webpack:///./node_modules/css-loader/dist/runtime/api.js","webpack:///./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js","webpack:///./src/dom/controls.js","webpack:///./src/dom/dom.css?9b6a","webpack:///./src/dom/hide_element.js","webpack:///./src/dom/main.js","webpack:///./src/utils/Url.js","webpack:///./src/utils/getChatBody.js"],"names":["muteBtnHTML","id","element","document","createElement","setAttribute","style","background","chrome","runtime","getURL","innerHTML","tryToAddControls","target","className","message","parentElement","addControlButton","addMuteButton","actionArea","senderId","muteButton","appendChild","display","addActionAreaEvents","actionsArea","addEventListener","event","getElementsByClassName","setIdToHideHandle","clickedId","substr","clickedName","children","innerText","storage","sync","get","data","idsToHide","filter","user","length","push","name","set","isExtensionOn","hideExistingMessages","chatBody","getChatBody","item","dataset","peer","createTryToInitInterval","controlsInterval","setInterval","tryToInitControls","clearInterval","lastChild","muteBtn","status","includes","messages","addNewMessageEventListener","newMessageHandler","returnMessagesEventListener","onChanged","addListener","changes","newValue","oldValue","init","url","UrlController","onChange","INTERVAL_TIME","_changeListeners","_interval","_url","window","location","href","cb","_createInterval","_clearInterval","currentUrl","_broadcast","oldUrl","newUrl","forEach","interval","_intervalTick"],"mappings":";QAAA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;;;;;;AClFA;AACA,kCAAkC,mBAAO,CAAC,wGAAmD;AAC7F;AACA;AACA,cAAc,QAAS,+BAA+B,2BAA2B,qBAAqB,+BAA+B,oBAAoB,2BAA2B,uBAAuB,2BAA2B,0EAA0E,mBAAmB,qBAAqB,2BAA2B,wDAAwD,iCAAiC,KAAK,kEAAkE,sBAAsB,2BAA2B,kBAAkB,kBAAkB,0BAA0B,0BAA0B,4BAA4B,+DAA+D,KAAK,mHAAmH,4BAA4B,mBAAmB,KAAK,uBAAuB,2BAA2B,yBAAyB,0BAA0B,8BAA8B,4BAA4B,oBAAoB,qBAAqB,4CAA4C,KAAK,2BAA2B,uCAAuC,KAAK;AACnuC;AACA;;;;;;;;;;;;;ACNa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;;AAEhB;AACA;AACA;;AAEA;AACA,4CAA4C,qBAAqB;AACjE;;AAEA;AACA,KAAK;AACL,IAAI;AACJ;;;AAGA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,qBAAqB,iBAAiB;AACtC;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,oBAAoB,qBAAqB;AACzC;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,8BAA8B;;AAE9B;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA,CAAC;;;AAGD;AACA;AACA;AACA,qDAAqD,cAAc;AACnE;AACA,C;;;;;;;;;;;;AC7Fa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA,uDAAuD;;AAEvD;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;;AAEA;AACA;;AAEA,iBAAiB,wBAAwB;AACzC;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,iBAAiB,iBAAiB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,gBAAgB,KAAwC,GAAG,sBAAiB,GAAG,SAAI;;AAEnF;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA,qEAAqE,qBAAqB,aAAa;;AAEvG;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA,yDAAyD;AACzD,GAAG;;AAEH;;;AAGA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AAC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","file":"dom.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/dom/main.js\");\n","// Imports\nvar ___CSS_LOADER_API_IMPORT___ = require(\"../../node_modules/css-loader/dist/runtime/api.js\");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.id, \".mute_message .mutetooltip {\\r\\n    visibility: hidden;\\r\\n    width: 120px;\\r\\n    background-color: #555;\\r\\n    color: #fff;\\r\\n    text-align: center;\\r\\n    padding: 5px 0;\\r\\n    border-radius: 6px;\\r\\n    \\r\\n    /* Position the tooltip text */\\r\\n    position: absolute;\\r\\n    z-index: 1;\\r\\n    bottom: 110%;\\r\\n    margin-left: -53px;\\r\\n    \\r\\n    /* Fade in tooltip */\\r\\n    opacity: 0;\\r\\n    transition: opacity 0.3s;\\r\\n}\\r\\n\\r\\n/* Tooltip arrow */\\r\\n.mute_message .mutetooltip::after {\\r\\n    content: \\\"\\\";\\r\\n    position: absolute;\\r\\n    top: 100%;\\r\\n    left: 50%;\\r\\n    margin-left: -5px;\\r\\n    border-width: 5px;\\r\\n    border-style: solid;\\r\\n    border-color: #555 transparent transparent transparent;\\r\\n}\\r\\n\\r\\n/* Show the tooltip text when you mouse over the tooltip container */\\r\\n.mute_message:hover .mutetooltip {\\r\\n    visibility: visible;\\r\\n    opacity: 1;\\r\\n}\\r\\n\\r\\n.mute_message {\\r\\n    margin-top: .46rem;\\r\\n    margin-left: 4px;\\r\\n    margin-right: 3px;\\r\\n    display: inline-block;\\r\\n    vertical-align: top;\\r\\n    width: 12px;\\r\\n    height: 12px;\\r\\n    background-size: contain !important;\\r\\n}\\r\\n\\r\\n.im-mess--actions {\\r\\n    margin-right: -30px !important;\\r\\n}\", \"\"]);\n// Exports\nmodule.exports = exports;\n","\"use strict\";\n\n/*\n  MIT License http://www.opensource.org/licenses/mit-license.php\n  Author Tobias Koppers @sokra\n*/\n// css base code, injected by the css-loader\n// eslint-disable-next-line func-names\nmodule.exports = function (useSourceMap) {\n  var list = []; // return the list of modules as css string\n\n  list.toString = function toString() {\n    return this.map(function (item) {\n      var content = cssWithMappingToString(item, useSourceMap);\n\n      if (item[2]) {\n        return \"@media \".concat(item[2], \" {\").concat(content, \"}\");\n      }\n\n      return content;\n    }).join('');\n  }; // import a list of modules into the list\n  // eslint-disable-next-line func-names\n\n\n  list.i = function (modules, mediaQuery, dedupe) {\n    if (typeof modules === 'string') {\n      // eslint-disable-next-line no-param-reassign\n      modules = [[null, modules, '']];\n    }\n\n    var alreadyImportedModules = {};\n\n    if (dedupe) {\n      for (var i = 0; i < this.length; i++) {\n        // eslint-disable-next-line prefer-destructuring\n        var id = this[i][0];\n\n        if (id != null) {\n          alreadyImportedModules[id] = true;\n        }\n      }\n    }\n\n    for (var _i = 0; _i < modules.length; _i++) {\n      var item = [].concat(modules[_i]);\n\n      if (dedupe && alreadyImportedModules[item[0]]) {\n        // eslint-disable-next-line no-continue\n        continue;\n      }\n\n      if (mediaQuery) {\n        if (!item[2]) {\n          item[2] = mediaQuery;\n        } else {\n          item[2] = \"\".concat(mediaQuery, \" and \").concat(item[2]);\n        }\n      }\n\n      list.push(item);\n    }\n  };\n\n  return list;\n};\n\nfunction cssWithMappingToString(item, useSourceMap) {\n  var content = item[1] || ''; // eslint-disable-next-line prefer-destructuring\n\n  var cssMapping = item[3];\n\n  if (!cssMapping) {\n    return content;\n  }\n\n  if (useSourceMap && typeof btoa === 'function') {\n    var sourceMapping = toComment(cssMapping);\n    var sourceURLs = cssMapping.sources.map(function (source) {\n      return \"/*# sourceURL=\".concat(cssMapping.sourceRoot || '').concat(source, \" */\");\n    });\n    return [content].concat(sourceURLs).concat([sourceMapping]).join('\\n');\n  }\n\n  return [content].join('\\n');\n} // Adapted from convert-source-map (MIT)\n\n\nfunction toComment(sourceMap) {\n  // eslint-disable-next-line no-undef\n  var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap))));\n  var data = \"sourceMappingURL=data:application/json;charset=utf-8;base64,\".concat(base64);\n  return \"/*# \".concat(data, \" */\");\n}","\"use strict\";\n\nvar isOldIE = function isOldIE() {\n  var memo;\n  return function memorize() {\n    if (typeof memo === 'undefined') {\n      // Test for IE <= 9 as proposed by Browserhacks\n      // @see http://browserhacks.com/#hack-e71d8692f65334173fee715c222cb805\n      // Tests for existence of standard globals is to allow style-loader\n      // to operate correctly into non-standard environments\n      // @see https://github.com/webpack-contrib/style-loader/issues/177\n      memo = Boolean(window && document && document.all && !window.atob);\n    }\n\n    return memo;\n  };\n}();\n\nvar getTarget = function getTarget() {\n  var memo = {};\n  return function memorize(target) {\n    if (typeof memo[target] === 'undefined') {\n      var styleTarget = document.querySelector(target); // Special case to return head of iframe instead of iframe itself\n\n      if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {\n        try {\n          // This will throw an exception if access to iframe is blocked\n          // due to cross-origin restrictions\n          styleTarget = styleTarget.contentDocument.head;\n        } catch (e) {\n          // istanbul ignore next\n          styleTarget = null;\n        }\n      }\n\n      memo[target] = styleTarget;\n    }\n\n    return memo[target];\n  };\n}();\n\nvar stylesInDom = [];\n\nfunction getIndexByIdentifier(identifier) {\n  var result = -1;\n\n  for (var i = 0; i < stylesInDom.length; i++) {\n    if (stylesInDom[i].identifier === identifier) {\n      result = i;\n      break;\n    }\n  }\n\n  return result;\n}\n\nfunction modulesToDom(list, options) {\n  var idCountMap = {};\n  var identifiers = [];\n\n  for (var i = 0; i < list.length; i++) {\n    var item = list[i];\n    var id = options.base ? item[0] + options.base : item[0];\n    var count = idCountMap[id] || 0;\n    var identifier = \"\".concat(id, \" \").concat(count);\n    idCountMap[id] = count + 1;\n    var index = getIndexByIdentifier(identifier);\n    var obj = {\n      css: item[1],\n      media: item[2],\n      sourceMap: item[3]\n    };\n\n    if (index !== -1) {\n      stylesInDom[index].references++;\n      stylesInDom[index].updater(obj);\n    } else {\n      stylesInDom.push({\n        identifier: identifier,\n        updater: addStyle(obj, options),\n        references: 1\n      });\n    }\n\n    identifiers.push(identifier);\n  }\n\n  return identifiers;\n}\n\nfunction insertStyleElement(options) {\n  var style = document.createElement('style');\n  var attributes = options.attributes || {};\n\n  if (typeof attributes.nonce === 'undefined') {\n    var nonce = typeof __webpack_nonce__ !== 'undefined' ? __webpack_nonce__ : null;\n\n    if (nonce) {\n      attributes.nonce = nonce;\n    }\n  }\n\n  Object.keys(attributes).forEach(function (key) {\n    style.setAttribute(key, attributes[key]);\n  });\n\n  if (typeof options.insert === 'function') {\n    options.insert(style);\n  } else {\n    var target = getTarget(options.insert || 'head');\n\n    if (!target) {\n      throw new Error(\"Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.\");\n    }\n\n    target.appendChild(style);\n  }\n\n  return style;\n}\n\nfunction removeStyleElement(style) {\n  // istanbul ignore if\n  if (style.parentNode === null) {\n    return false;\n  }\n\n  style.parentNode.removeChild(style);\n}\n/* istanbul ignore next  */\n\n\nvar replaceText = function replaceText() {\n  var textStore = [];\n  return function replace(index, replacement) {\n    textStore[index] = replacement;\n    return textStore.filter(Boolean).join('\\n');\n  };\n}();\n\nfunction applyToSingletonTag(style, index, remove, obj) {\n  var css = remove ? '' : obj.media ? \"@media \".concat(obj.media, \" {\").concat(obj.css, \"}\") : obj.css; // For old IE\n\n  /* istanbul ignore if  */\n\n  if (style.styleSheet) {\n    style.styleSheet.cssText = replaceText(index, css);\n  } else {\n    var cssNode = document.createTextNode(css);\n    var childNodes = style.childNodes;\n\n    if (childNodes[index]) {\n      style.removeChild(childNodes[index]);\n    }\n\n    if (childNodes.length) {\n      style.insertBefore(cssNode, childNodes[index]);\n    } else {\n      style.appendChild(cssNode);\n    }\n  }\n}\n\nfunction applyToTag(style, options, obj) {\n  var css = obj.css;\n  var media = obj.media;\n  var sourceMap = obj.sourceMap;\n\n  if (media) {\n    style.setAttribute('media', media);\n  } else {\n    style.removeAttribute('media');\n  }\n\n  if (sourceMap && btoa) {\n    css += \"\\n/*# sourceMappingURL=data:application/json;base64,\".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), \" */\");\n  } // For old IE\n\n  /* istanbul ignore if  */\n\n\n  if (style.styleSheet) {\n    style.styleSheet.cssText = css;\n  } else {\n    while (style.firstChild) {\n      style.removeChild(style.firstChild);\n    }\n\n    style.appendChild(document.createTextNode(css));\n  }\n}\n\nvar singleton = null;\nvar singletonCounter = 0;\n\nfunction addStyle(obj, options) {\n  var style;\n  var update;\n  var remove;\n\n  if (options.singleton) {\n    var styleIndex = singletonCounter++;\n    style = singleton || (singleton = insertStyleElement(options));\n    update = applyToSingletonTag.bind(null, style, styleIndex, false);\n    remove = applyToSingletonTag.bind(null, style, styleIndex, true);\n  } else {\n    style = insertStyleElement(options);\n    update = applyToTag.bind(null, style, options);\n\n    remove = function remove() {\n      removeStyleElement(style);\n    };\n  }\n\n  update(obj);\n  return function updateStyle(newObj) {\n    if (newObj) {\n      if (newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap) {\n        return;\n      }\n\n      update(obj = newObj);\n    } else {\n      remove();\n    }\n  };\n}\n\nmodule.exports = function (list, options) {\n  options = options || {}; // Force single-tag solution on IE6-9, which has a hard limit on the # of <style>\n  // tags it will allow on a page\n\n  if (!options.singleton && typeof options.singleton !== 'boolean') {\n    options.singleton = isOldIE();\n  }\n\n  list = list || [];\n  var lastIdentifiers = modulesToDom(list, options);\n  return function update(newList) {\n    newList = newList || [];\n\n    if (Object.prototype.toString.call(newList) !== '[object Array]') {\n      return;\n    }\n\n    for (var i = 0; i < lastIdentifiers.length; i++) {\n      var identifier = lastIdentifiers[i];\n      var index = getIndexByIdentifier(identifier);\n      stylesInDom[index].references--;\n    }\n\n    var newLastIdentifiers = modulesToDom(newList, options);\n\n    for (var _i = 0; _i < lastIdentifiers.length; _i++) {\n      var _identifier = lastIdentifiers[_i];\n\n      var _index = getIndexByIdentifier(_identifier);\n\n      if (stylesInDom[_index].references === 0) {\n        stylesInDom[_index].updater();\n\n        stylesInDom.splice(_index, 1);\n      }\n    }\n\n    lastIdentifiers = newLastIdentifiers;\n  };\n};","/**\r\n *\r\n * @param id {String}\r\n * @return {HTMLSpanElement}\r\n */\r\nimport {getChatBody} from \"../utils/getChatBody\";\r\n\r\nfunction muteBtnHTML(id) {\r\n    const element = document.createElement('span');\r\n    element.setAttribute('class', 'mute_message');\r\n    element.setAttribute('id', `mute${id}`);\r\n    element.style.background = `url(${chrome.runtime.getURL(\"assets/mute.png\")}) center no-repeat`;\r\n    element.innerHTML ='<span class=\"mutetooltip\">Заглушить</span>';\r\n    return element;\r\n}\r\n\r\nexport function tryToAddControls(target) {\r\n    if (target.className === 'im-mess--check fl_l') {\r\n        const message = target.parentElement;\r\n        addControlButton(message)\r\n    }\r\n}\r\n\r\n/**\r\n * Create mute button and inset it to the actionArea\r\n * @param actionArea {HTMLElement}\r\n * @param senderId {String}\r\n * @return {HTMLElement}\r\n */\r\nfunction addMuteButton(actionArea, senderId) {\r\n    const muteButton = muteBtnHTML(senderId);\r\n    actionArea.appendChild(muteButton);\r\n    muteButton.style.display = \"none\";\r\n    return muteButton;\r\n}\r\n\r\n/**\r\n * Add event listeners to the actionArea\r\n * @param actionsArea {HTMLElement}\r\n */\r\nfunction addActionAreaEvents(actionsArea) {\r\n    actionsArea.parentElement.addEventListener(\"mouseenter\", function (event) {\r\n        event.target.getElementsByClassName(\"mute_message\")[0].style.display = \"inline-block\";\r\n    });\r\n\r\n    actionsArea.parentElement.addEventListener(\"mouseleave\", function (event) {\r\n        event.target.getElementsByClassName(\"mute_message\")[0].style.display = \"none\";\r\n    });\r\n}\r\n\r\n/**\r\n *\r\n * @return {function(...[]=)}\r\n */\r\nfunction setIdToHideHandle() {\r\n    return function (event) {\r\n        const clickedId = event.target.id.substr(4);     // get id of sender from element id\r\n        let clickedName = event.target.parentElement.parentElement.parentElement.parentElement;\r\n        clickedName = clickedName.children[0].children[0].children[0].innerText;\r\n\r\n        chrome.storage.sync.get('idsToHide', function(data) {\r\n            let idsToHide = data.idsToHide || [];\r\n            if (idsToHide.filter(user => user.id == clickedId).length === 0) {\r\n                idsToHide.push({\r\n                    id: clickedId,\r\n                    name: clickedName\r\n                });\r\n                chrome.storage.sync.set({idsToHide: idsToHide}, function () {\r\n                    chrome.storage.sync.get('isExtensionOn', function(data) {\r\n                        if (data.isExtensionOn) {\r\n                            hideExistingMessages();\r\n                        }\r\n                    });\r\n                });\r\n            }\r\n        });\r\n    }\r\n}\r\n\r\nexport function hideExistingMessages() {\r\n    chrome.storage.sync.get('idsToHide', function(data) {\r\n        const chatBody = getChatBody();\r\n        for (let item of chatBody.children) {\r\n            if (data.idsToHide.filter(user => user.id == item.dataset.peer).length > 0) {\r\n                item.style.display = \"none\";\r\n            }\r\n        }\r\n    })\r\n}\r\n\r\n// Try to add controls until successful. Needed for page refresh.\r\nexport function createTryToInitInterval() {\r\n    const controlsInterval = setInterval(function () {\r\n        if(!tryToInitControls(controlsInterval)){\r\n            clearInterval(controlsInterval);\r\n        }\r\n    }, 200)\r\n    return controlsInterval;\r\n}\r\n\r\n/**\r\n *\r\n * @param message {HTMLElement}\r\n */\r\nfunction addControlButton(message) {\r\n    const actionsArea = message.getElementsByClassName(\"im-mess--actions\")[0];\r\n    if (actionsArea && actionsArea.lastChild.className !== \"mute_message\") {\r\n        const senderId = message.parentElement.parentElement.parentElement[\"dataset\"].peer;\r\n        const muteBtn = addMuteButton(actionsArea, senderId);\r\n        addActionAreaEvents(actionsArea);\r\n        muteBtn.addEventListener(\"click\", setIdToHideHandle());\r\n        return true;\r\n    } else {\r\n        return false;\r\n    }\r\n}\r\n\r\nexport function tryToInitControls() {\r\n    let status = true;\r\n    const chatBody = getChatBody();\r\n    if(!chatBody) return false;\r\n    for (let item of chatBody.children) {\r\n        if (item.className.includes('im-mess-stack _im_mess_stack')) {\r\n            let messages = item.children[1].children[1].getElementsByClassName('im-mess _im_mess');\r\n            for (let message of messages) {\r\n                status = addControlButton(message, chatBody)\r\n            }\r\n        }\r\n    }\r\n    return status;\r\n}","var api = require(\"!../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\");\n            var content = require(\"!!../../node_modules/css-loader/dist/cjs.js!./dom.css\");\n\n            content = content.__esModule ? content.default : content;\n\n            if (typeof content === 'string') {\n              content = [[module.id, content, '']];\n            }\n\nvar options = {};\n\noptions.insert = \"head\";\noptions.singleton = false;\n\nvar update = api(content, options);\n\nvar exported = content.locals ? content.locals : {};\n\n\n\nmodule.exports = exported;","import {getChatBody} from \"../utils/getChatBody\";\r\nimport {tryToAddControls, hideExistingMessages} from \"./controls\";\r\n\r\nexport function addNewMessageEventListener() {\r\n    const chatBody = getChatBody();\r\n    chatBody.addEventListener('DOMNodeInserted', function(event) {\r\n        newMessageHandler(event.target)\r\n    });\r\n}\r\n\r\nfunction newMessageHandler(message) {\r\n    tryToAddControls(message);\r\n    if (message.className === 'im-mess-stack _im_mess_stack ') {\r\n        chrome.storage.sync.get('isExtensionOn', function(data) {\r\n            if (data.isExtensionOn) {\r\n                chrome.storage.sync.get('idsToHide', function(data) {\r\n                    if (data.idsToHide.filter(user => user.id == message.dataset.peer).length > 0) {\r\n                        message.style.display = \"none\";\r\n                    }\r\n                });\r\n            }\r\n        });\r\n    }\r\n}\r\n\r\nexport function returnMessagesEventListener() {\r\n    chrome.storage.onChanged.addListener(function(changes) {\r\n        const isExtensionOn = changes.isExtensionOn;\r\n        const idsToHide = changes.idsToHide;\r\n        const chatBody = getChatBody();\r\n        if (isExtensionOn) {\r\n            if (isExtensionOn.newValue === false) {\r\n                for (let item of chatBody.children) {\r\n                    item.style.display = \"block\";\r\n                }\r\n            } else {\r\n                hideExistingMessages();\r\n            }\r\n        }\r\n        if (idsToHide) {\r\n            chrome.storage.sync.get('isExtensionOn', function(data) {\r\n                if (data.isExtensionOn) {\r\n                    if (idsToHide.newValue.length < idsToHide.oldValue.length) {\r\n                        // for (let item of chatBody.children) {\r\n                        //     item.style.display = \"block\";\r\n                        // }\r\n                        // hideExistingMessages();\r\n                        for (let item of chatBody.children) {\r\n                            if (idsToHide.newValue.filter(user => user.id == item.dataset.peer).length === 0) {\r\n                                item.style.display = \"block\";\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n            });\r\n        }\r\n    });\r\n}","import './dom.css'\r\nimport {createTryToInitInterval, hideExistingMessages, tryToInitControls} from \"./controls\";\r\nimport {UrlController} from \"../utils/Url\";\r\nimport {addNewMessageEventListener, returnMessagesEventListener} from \"./hide_element\";\r\n\r\nfunction init() {\r\n    const url = new UrlController();\r\n    url.onChange(() => {\r\n        if (tryToInitControls()) {\r\n            createTryToInitInterval();\r\n            addNewMessageEventListener();\r\n            returnMessagesEventListener();\r\n            hideExistingMessages();\r\n        }\r\n    })\r\n}\r\n\r\ninit();","const INTERVAL_TIME = 100;\r\n\r\nexport class UrlController {\r\n\r\n    constructor() {\r\n        this._changeListeners = [];\r\n        this._interval = null;\r\n        this._url = window.location.href;\r\n    }\r\n\r\n    onChange(cb) {\r\n        this._changeListeners.push(cb);\r\n        if (this._interval === null) {\r\n            this._createInterval();\r\n        }\r\n    }\r\n\r\n    removeEventListener(cb) {\r\n        this._changeListeners = this._changeListeners.filter(item=>item !== cb);\r\n        if(this._changeListeners.length === 0) {\r\n            this._clearInterval();\r\n        }\r\n    }\r\n\r\n    _intervalTick() {\r\n        const currentUrl = window.location.href;\r\n        if (currentUrl !== this.url) {\r\n            this._broadcast(this.url, currentUrl);\r\n            this.url = currentUrl;\r\n        }\r\n\r\n    }\r\n\r\n    _broadcast(oldUrl, newUrl) {\r\n        this._changeListeners.forEach(cb => cb(oldUrl, newUrl));\r\n    }\r\n\r\n    _createInterval() {\r\n        this.interval = setInterval(() => this._intervalTick(), INTERVAL_TIME)\r\n    }\r\n\r\n    _clearInterval() {\r\n        clearInterval(this.interval)\r\n        this.interval = null\r\n    }\r\n\r\n}","export function getChatBody() {\r\n    return document.getElementsByClassName(\"_im_peer_history im-page-chat-contain\")[0];\r\n}"],"sourceRoot":""}