mirror of
https://github.com/anatolykopyl/vk-mute.git
synced 2026-03-26 21:05:16 +00:00
950 lines
83 KiB
JavaScript
950 lines
83 KiB
JavaScript
/******/ (() => { // webpackBootstrap
|
|
/******/ var __webpack_modules__ = ({
|
|
|
|
/***/ "./src/dom/controls.js":
|
|
/*!*****************************!*\
|
|
!*** ./src/dom/controls.js ***!
|
|
\*****************************/
|
|
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
/* harmony export */ "createTryToInitInterval": () => (/* binding */ createTryToInitInterval),
|
|
/* harmony export */ "hideExistingMessages": () => (/* binding */ hideExistingMessages),
|
|
/* harmony export */ "tryToAddControls": () => (/* binding */ tryToAddControls),
|
|
/* harmony export */ "tryToInitControls": () => (/* binding */ tryToInitControls)
|
|
/* harmony export */ });
|
|
/* harmony import */ var _utils_getChatBody__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/getChatBody */ "./src/utils/getChatBody.js");
|
|
/* harmony import */ var _mute_svg__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./mute.svg */ "./src/dom/mute.svg");
|
|
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', 'im-mess--mute');
|
|
element.setAttribute('id', "mute".concat(id));
|
|
element.setAttribute('label', 'Заглушить');
|
|
element.innerHTML = "".concat(_mute_svg__WEBPACK_IMPORTED_MODULE_1__["default"], "<div class=\"mute_tooltip tt_w tt_black tt_down\"><div class=\"tt_text\">\u0417\u0430\u0433\u043B\u0443\u0448\u0438\u0442\u044C</div></div>");
|
|
return element;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param target {HTMLElenemt}
|
|
*/
|
|
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.visibility = 'hidden';
|
|
return muteButton;
|
|
}
|
|
|
|
/**
|
|
* Add event listeners to the actionArea
|
|
* @param actionsArea {HTMLElement}
|
|
*/
|
|
function addActionAreaEvents(actionsArea) {
|
|
actionsArea.parentElement.addEventListener('mouseenter', function (event) {
|
|
event.target.getElementsByClassName('im-mess--mute')[0].style.visibility = 'visible';
|
|
});
|
|
actionsArea.parentElement.addEventListener('mouseleave', function (event) {
|
|
event.target.getElementsByClassName('im-mess--mute')[0].style.visibility = 'hidden';
|
|
});
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @this {HTMLElement}
|
|
*/
|
|
function setIdToHideHandle() {
|
|
var clickedId = this.id.substring(4);
|
|
var clickedName = this.parentElement.parentElement.parentElement.parentElement;
|
|
clickedName = clickedName.children[0].children[0].children[0].textContent;
|
|
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 = (0,_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) {
|
|
// Check if message is not an outgoing one
|
|
if (!message.classList.contains('im-mess_out')) {
|
|
var actionsArea = message.getElementsByClassName('im-mess--actions')[0];
|
|
if (actionsArea && actionsArea.lastChild.className !== 'im-mess--mute') {
|
|
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 = (0,_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);
|
|
}
|
|
} catch (err) {
|
|
_iterator3.e(err);
|
|
} finally {
|
|
_iterator3.f();
|
|
}
|
|
}
|
|
}
|
|
} catch (err) {
|
|
_iterator2.e(err);
|
|
} finally {
|
|
_iterator2.f();
|
|
}
|
|
return status;
|
|
}
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./src/dom/hide_element.js":
|
|
/*!*********************************!*\
|
|
!*** ./src/dom/hide_element.js ***!
|
|
\*********************************/
|
|
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
/* harmony export */ "addNewMessageEventListener": () => (/* binding */ addNewMessageEventListener),
|
|
/* harmony export */ "returnMessagesEventListener": () => (/* binding */ returnMessagesEventListener)
|
|
/* harmony export */ });
|
|
/* 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 = (0,_utils_getChatBody__WEBPACK_IMPORTED_MODULE_0__.getChatBody)();
|
|
chatBody.addEventListener('DOMNodeInserted', function (event) {
|
|
newMessageHandler(event.target);
|
|
});
|
|
}
|
|
function newMessageHandler(message) {
|
|
(0,_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 = (0,_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 {
|
|
(0,_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) {
|
|
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/utils/Url.js":
|
|
/*!**************************!*\
|
|
!*** ./src/utils/Url.js ***!
|
|
\**************************/
|
|
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
/* harmony export */ "UrlController": () => (/* binding */ UrlController)
|
|
/* harmony export */ });
|
|
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 ***!
|
|
\**********************************/
|
|
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
/* harmony export */ "getChatBody": () => (/* binding */ getChatBody)
|
|
/* harmony export */ });
|
|
function getChatBody() {
|
|
return document.getElementsByClassName('_im_peer_history im-page-chat-contain')[0];
|
|
}
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./node_modules/css-loader/dist/cjs.js!./src/dom/dom.css":
|
|
/*!***************************************************************!*\
|
|
!*** ./node_modules/css-loader/dist/cjs.js!./src/dom/dom.css ***!
|
|
\***************************************************************/
|
|
/***/ ((module, __webpack_exports__, __webpack_require__) => {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
|
|
/* harmony export */ });
|
|
/* harmony import */ var _node_modules_css_loader_dist_runtime_sourceMaps_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../node_modules/css-loader/dist/runtime/sourceMaps.js */ "./node_modules/css-loader/dist/runtime/sourceMaps.js");
|
|
/* harmony import */ var _node_modules_css_loader_dist_runtime_sourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_sourceMaps_js__WEBPACK_IMPORTED_MODULE_0__);
|
|
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");
|
|
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__);
|
|
// Imports
|
|
|
|
|
|
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()((_node_modules_css_loader_dist_runtime_sourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default()));
|
|
// Module
|
|
___CSS_LOADER_EXPORT___.push([module.id, ".mute_tooltip {\n position: absolute;\n left: -50px;\n top: -33px;\n display: none;\n}\n\n.mute_tooltip::after {\n left: 61px !important;\n}\n\n/* Show the tooltip text when you mouse over the tooltip container */\n.im-mess--mute:hover .mute_tooltip {\n display: block !important;\n opacity: 1;\n}\n\n.im-mess--mute {\n position: relative;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: 24px;\n height: 24px;\n opacity: .5;\n color: var(--vkui--color_icon_secondary);\n}\n\n.im-mess--mute:hover {\n opacity: 1;\n}\n\n.im-mess--actions {\n margin-right: -30px !important;\n}", "",{"version":3,"sources":["webpack://./src/dom/dom.css"],"names":[],"mappings":"AAAA;EACE,kBAAkB;EAClB,WAAW;EACX,UAAU;EACV,aAAa;AACf;;AAEA;EACE,qBAAqB;AACvB;;AAEA,oEAAoE;AACpE;EACE,yBAAyB;EACzB,UAAU;AACZ;;AAEA;EACE,kBAAkB;EAClB,oBAAoB;EACpB,mBAAmB;EACnB,uBAAuB;EACvB,WAAW;EACX,YAAY;EACZ,WAAW;EACX,wCAAwC;AAC1C;;AAEA;EACE,UAAU;AACZ;;AAEA;EACE,8BAA8B;AAChC","sourcesContent":[".mute_tooltip {\n position: absolute;\n left: -50px;\n top: -33px;\n display: none;\n}\n\n.mute_tooltip::after {\n left: 61px !important;\n}\n\n/* Show the tooltip text when you mouse over the tooltip container */\n.im-mess--mute:hover .mute_tooltip {\n display: block !important;\n opacity: 1;\n}\n\n.im-mess--mute {\n position: relative;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: 24px;\n height: 24px;\n opacity: .5;\n color: var(--vkui--color_icon_secondary);\n}\n\n.im-mess--mute:hover {\n opacity: 1;\n}\n\n.im-mess--actions {\n margin-right: -30px !important;\n}"],"sourceRoot":""}]);
|
|
// Exports
|
|
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___);
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./node_modules/css-loader/dist/runtime/api.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/css-loader/dist/runtime/api.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module) => {
|
|
|
|
"use strict";
|
|
|
|
|
|
/*
|
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
|
Author Tobias Koppers @sokra
|
|
*/
|
|
module.exports = function (cssWithMappingToString) {
|
|
var list = [];
|
|
|
|
// return the list of modules as css string
|
|
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("");
|
|
};
|
|
|
|
// import a list of modules into the list
|
|
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;
|
|
};
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./node_modules/css-loader/dist/runtime/sourceMaps.js":
|
|
/*!************************************************************!*\
|
|
!*** ./node_modules/css-loader/dist/runtime/sourceMaps.js ***!
|
|
\************************************************************/
|
|
/***/ ((module) => {
|
|
|
|
"use strict";
|
|
|
|
|
|
module.exports = function (item) {
|
|
var content = item[1];
|
|
var cssMapping = item[3];
|
|
if (!cssMapping) {
|
|
return content;
|
|
}
|
|
if (typeof btoa === "function") {
|
|
var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(cssMapping))));
|
|
var data = "sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(base64);
|
|
var sourceMapping = "/*# ".concat(data, " */");
|
|
return [content].concat([sourceMapping]).join("\n");
|
|
}
|
|
return [content].join("\n");
|
|
};
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./src/dom/mute.svg":
|
|
/*!**************************!*\
|
|
!*** ./src/dom/mute.svg ***!
|
|
\**************************/
|
|
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
|
|
/* harmony export */ });
|
|
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("<svg \n xmlns=\"http://www.w3.org/2000/svg\" \n width=\"16\" \n height=\"16\" \n fill=\"currentColor\" \n viewBox=\"2 1 13 13\"\n>\n <path d=\"M4.69 5.5 11 11.8v1.7c0 .3-.23.47-.49.5l-3.63-3.5H4a1 1 0 0 1-1-1v-3a1 1 0 0 1 1-1h.69Zm.77-2.85 2.2 2.19L10.5 2.5c.27.02.49.2.49.48v5.2l2.6 2.6a.75.75 0 0 1-1.06 1.06L4.4 3.71a.75.75 0 0 1 1.06-1.06Z\"></path>\n</svg>\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./src/dom/dom.css":
|
|
/*!*************************!*\
|
|
!*** ./src/dom/dom.css ***!
|
|
\*************************/
|
|
/***/ ((module, __unused_webpack_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.id, content, '']];
|
|
}
|
|
|
|
var options = {};
|
|
|
|
options.insert = "head";
|
|
options.singleton = false;
|
|
|
|
var update = api(content, options);
|
|
|
|
var exported = content.locals ? content.locals : {};
|
|
|
|
|
|
|
|
module.exports = exported;
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js":
|
|
/*!****************************************************************************!*\
|
|
!*** ./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js ***!
|
|
\****************************************************************************/
|
|
/***/ ((module, __unused_webpack_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 : 0;
|
|
|
|
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;
|
|
};
|
|
};
|
|
|
|
/***/ })
|
|
|
|
/******/ });
|
|
/************************************************************************/
|
|
/******/ // The module cache
|
|
/******/ var __webpack_module_cache__ = {};
|
|
/******/
|
|
/******/ // The require function
|
|
/******/ function __webpack_require__(moduleId) {
|
|
/******/ // Check if module is in cache
|
|
/******/ var cachedModule = __webpack_module_cache__[moduleId];
|
|
/******/ if (cachedModule !== undefined) {
|
|
/******/ return cachedModule.exports;
|
|
/******/ }
|
|
/******/ // Create a new module (and put it into the cache)
|
|
/******/ var module = __webpack_module_cache__[moduleId] = {
|
|
/******/ id: moduleId,
|
|
/******/ // no module.loaded needed
|
|
/******/ exports: {}
|
|
/******/ };
|
|
/******/
|
|
/******/ // Execute the module function
|
|
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
|
|
/******/
|
|
/******/ // Return the exports of the module
|
|
/******/ return module.exports;
|
|
/******/ }
|
|
/******/
|
|
/************************************************************************/
|
|
/******/ /* webpack/runtime/compat get default export */
|
|
/******/ (() => {
|
|
/******/ // getDefaultExport function for compatibility with non-harmony modules
|
|
/******/ __webpack_require__.n = (module) => {
|
|
/******/ var getter = module && module.__esModule ?
|
|
/******/ () => (module['default']) :
|
|
/******/ () => (module);
|
|
/******/ __webpack_require__.d(getter, { a: getter });
|
|
/******/ return getter;
|
|
/******/ };
|
|
/******/ })();
|
|
/******/
|
|
/******/ /* webpack/runtime/define property getters */
|
|
/******/ (() => {
|
|
/******/ // define getter functions for harmony exports
|
|
/******/ __webpack_require__.d = (exports, definition) => {
|
|
/******/ for(var key in definition) {
|
|
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
|
|
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
|
|
/******/ }
|
|
/******/ }
|
|
/******/ };
|
|
/******/ })();
|
|
/******/
|
|
/******/ /* webpack/runtime/hasOwnProperty shorthand */
|
|
/******/ (() => {
|
|
/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
|
|
/******/ })();
|
|
/******/
|
|
/******/ /* webpack/runtime/make namespace object */
|
|
/******/ (() => {
|
|
/******/ // define __esModule on exports
|
|
/******/ __webpack_require__.r = (exports) => {
|
|
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
|
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
/******/ }
|
|
/******/ Object.defineProperty(exports, '__esModule', { value: true });
|
|
/******/ };
|
|
/******/ })();
|
|
/******/
|
|
/******/ /* webpack/runtime/nonce */
|
|
/******/ (() => {
|
|
/******/ __webpack_require__.nc = undefined;
|
|
/******/ })();
|
|
/******/
|
|
/************************************************************************/
|
|
var __webpack_exports__ = {};
|
|
// This entry need to be wrapped in an IIFE because it need to be in strict mode.
|
|
(() => {
|
|
"use strict";
|
|
/*!*************************!*\
|
|
!*** ./src/dom/main.js ***!
|
|
\*************************/
|
|
__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 _utils_Url__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/Url */ "./src/utils/Url.js");
|
|
/* harmony import */ var _controls__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./controls */ "./src/dom/controls.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_1__.UrlController();
|
|
url.onChange(function () {
|
|
if ((0,_controls__WEBPACK_IMPORTED_MODULE_2__.tryToInitControls)()) {
|
|
(0,_controls__WEBPACK_IMPORTED_MODULE_2__.createTryToInitInterval)();
|
|
(0,_hide_element__WEBPACK_IMPORTED_MODULE_3__.addNewMessageEventListener)();
|
|
(0,_hide_element__WEBPACK_IMPORTED_MODULE_3__.returnMessagesEventListener)();
|
|
chrome.storage.sync.get('isExtensionOn', function (data) {
|
|
if (data.isExtensionOn) (0,_controls__WEBPACK_IMPORTED_MODULE_2__.hideExistingMessages)();
|
|
});
|
|
}
|
|
});
|
|
}
|
|
init();
|
|
})();
|
|
|
|
/******/ })()
|
|
;
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"dom.js","mappings":"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AAEzF;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;;;;AAIA;;;;;;;;;;;ACpBa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA,wDAAwD;;AAExD;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;;AAEA;AACA;;AAEA,kBAAkB,wBAAwB;AAC1C;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,kBAAkB,iBAAiB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,gBAAgB,KAAwC,GAAG,sBAAiB,GAAG,CAAI;;AAEnF;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA,IAAI;AACJ;;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,cAAc;;AAExG;;AAEA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA,yDAAyD;AACzD,IAAI;;AAEJ;;;AAGA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,MAAM;AACN;AACA;AACA;AACA;;AAEA;AACA,2BAA2B;AAC3B;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,oBAAoB,4BAA4B;AAChD;AACA;AACA;AACA;;AAEA;;AAEA,qBAAqB,6BAA6B;AAClD;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;;;;;UC5QA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA;WACA;WACA,iCAAiC,WAAW;WAC5C;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;WCNA;;;;;;;;;;;;;;;;;ACAkB;AAC0B;AACiD;AACL;AAExF,SAASsF,IAAIA,CAAA,EAAG;EACd,IAAMP,GAAG,GAAG,IAAIjB,qDAAa,CAAC,CAAC;EAC/BiB,GAAG,CAACP,QAAQ,CAAC,YAAM;IACjB,IAAIhC,4DAAiB,CAAC,CAAC,EAAE;MACvBH,kEAAuB,CAAC,CAAC;MACzBgB,yEAA0B,CAAC,CAAC;MAC5BE,0EAA2B,CAAC,CAAC;MAC7BhD,MAAM,CAACC,OAAO,CAACC,IAAI,CAACC,GAAG,CAAC,eAAe,EAAE,UAACC,IAAI,EAAK;QACjD,IAAIA,IAAI,CAACQ,aAAa,EACpBC,+DAAoB,CAAC,CAAC;MAC1B,CAAC,CAAC;IACJ;EACF,CAAC,CAAC;AACJ;AAEAkE,IAAI,CAAC,CAAC,C","sources":["webpack://vk-mute/./src/dom/controls.js","webpack://vk-mute/./src/dom/hide_element.js","webpack://vk-mute/./src/utils/Url.js","webpack://vk-mute/./src/utils/getChatBody.js","webpack://vk-mute/./src/dom/dom.css","webpack://vk-mute/./node_modules/css-loader/dist/runtime/api.js","webpack://vk-mute/./node_modules/css-loader/dist/runtime/sourceMaps.js","webpack://vk-mute/./src/dom/mute.svg","webpack://vk-mute/./src/dom/dom.css?9b6a","webpack://vk-mute/./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js","webpack://vk-mute/webpack/bootstrap","webpack://vk-mute/webpack/runtime/compat get default export","webpack://vk-mute/webpack/runtime/define property getters","webpack://vk-mute/webpack/runtime/hasOwnProperty shorthand","webpack://vk-mute/webpack/runtime/make namespace object","webpack://vk-mute/webpack/runtime/nonce","webpack://vk-mute/./src/dom/main.js"],"sourcesContent":["import { getChatBody } from '../utils/getChatBody'\nimport muteSvg from './mute.svg'\n\n/**\n *\n * @param id {String}\n * @return {HTMLSpanElement}\n */\nfunction muteBtnHTML(id) {\n  const element = document.createElement('span')\n  element.setAttribute('class', 'im-mess--mute')\n  element.setAttribute('id', `mute${id}`)\n  element.setAttribute('label', 'Заглушить')\n  element.innerHTML = `${muteSvg}<div class=\"mute_tooltip tt_w tt_black tt_down\"><div class=\"tt_text\">Заглушить</div></div>`\n  return element\n}\n\n/**\n *\n * @param target {HTMLElenemt}\n */\nexport function tryToAddControls(target) {\n  if (target.className === 'im-mess--check fl_l') {\n    const message = target.parentElement\n    addControlButton(message)\n  }\n}\n\n/**\n * Create mute button and inset it to the actionArea\n * @param actionArea {HTMLElement}\n * @param senderId {String}\n * @return {HTMLElement}\n */\nfunction addMuteButton(actionArea, senderId) {\n  const muteButton = muteBtnHTML(senderId)\n  actionArea.appendChild(muteButton)\n  muteButton.style.visibility = 'hidden'\n  return muteButton\n}\n\n/**\n * Add event listeners to the actionArea\n * @param actionsArea {HTMLElement}\n */\nfunction addActionAreaEvents(actionsArea) {\n  actionsArea.parentElement.addEventListener('mouseenter', (event) => {\n    event.target.getElementsByClassName('im-mess--mute')[0].style.visibility = 'visible'\n  })\n\n  actionsArea.parentElement.addEventListener('mouseleave', (event) => {\n    event.target.getElementsByClassName('im-mess--mute')[0].style.visibility = 'hidden'\n  })\n}\n\n/**\n *\n * @this {HTMLElement}\n */\nfunction setIdToHideHandle() {\n  const clickedId = this.id.substring(4)\n  let clickedName = this.parentElement.parentElement.parentElement.parentElement\n  clickedName = clickedName.children[0].children[0].children[0].textContent\n\n  chrome.storage.sync.get('idsToHide', (data) => {\n    const idsToHide = data.idsToHide || []\n    if (idsToHide.filter(user => user.id === clickedId).length === 0) {\n      idsToHide.push({\n        id: clickedId,\n        name: clickedName,\n      })\n      chrome.storage.sync.set({ idsToHide }, () => {\n        chrome.storage.sync.get('isExtensionOn', (data) => {\n          if (data.isExtensionOn)\n            hideExistingMessages()\n        })\n      })\n    }\n  })\n}\n\nexport function hideExistingMessages() {\n  chrome.storage.sync.get('idsToHide', (data) => {\n    const chatBody = getChatBody()\n    for (const item of chatBody.children) {\n      if (data.idsToHide.filter(user => user.id === item.dataset.peer).length > 0)\n        item.style.display = 'none'\n    }\n  })\n}\n\n// Try to add controls until successful. Needed for page refresh.\nexport function createTryToInitInterval() {\n  const controlsInterval = setInterval(() => {\n    if (!tryToInitControls(controlsInterval))\n      clearInterval(controlsInterval)\n  }, 200)\n  return controlsInterval\n}\n\n/**\n *\n * @param message {HTMLElement}\n */\nfunction addControlButton(message) {\n  // Check if message is not an outgoing one\n  if (!message.classList.contains('im-mess_out')) {\n    const actionsArea = message.getElementsByClassName('im-mess--actions')[0]\n    if (actionsArea && actionsArea.lastChild.className !== 'im-mess--mute') {\n      const senderId = message.parentElement.parentElement.parentElement.dataset.peer\n      const muteBtn = addMuteButton(actionsArea, senderId)\n      addActionAreaEvents(actionsArea)\n      muteBtn.addEventListener('click', setIdToHideHandle)\n      return true\n    }\n    else {\n      return false\n    }\n  }\n}\n\nexport function tryToInitControls() {\n  let status = true\n  const chatBody = getChatBody()\n  if (!chatBody)\n    return false\n  for (const item of chatBody.children) {\n    if (item.className.includes('im-mess-stack _im_mess_stack')) {\n      const messages = item.children[1].children[1].getElementsByClassName('im-mess _im_mess')\n      for (const message of messages)\n        status = addControlButton(message)\n    }\n  }\n  return status\n}\n","import { getChatBody } from '../utils/getChatBody'\nimport { hideExistingMessages, tryToAddControls } from './controls'\n\nexport function addNewMessageEventListener() {\n  const chatBody = getChatBody()\n  chatBody.addEventListener('DOMNodeInserted', (event) => {\n    newMessageHandler(event.target)\n  })\n}\n\nfunction newMessageHandler(message) {\n  tryToAddControls(message)\n  if (message.className === 'im-mess-stack _im_mess_stack ') {\n    chrome.storage.sync.get('isExtensionOn', (data) => {\n      if (data.isExtensionOn) {\n        chrome.storage.sync.get('idsToHide', (data) => {\n          if (data.idsToHide.filter(user => user.id === message.dataset.peer).length > 0)\n            message.style.display = 'none'\n        })\n      }\n    })\n  }\n}\n\nexport function returnMessagesEventListener() {\n  chrome.storage.onChanged.addListener((changes) => {\n    const isExtensionOn = changes.isExtensionOn\n    const idsToHide = changes.idsToHide\n    const chatBody = getChatBody()\n    if (isExtensionOn) {\n      if (isExtensionOn.newValue === false) {\n        for (const item of chatBody.children)\n          item.style.display = 'block'\n      }\n      else {\n        hideExistingMessages()\n      }\n    }\n    if (idsToHide) {\n      chrome.storage.sync.get('isExtensionOn', (data) => {\n        if (data.isExtensionOn) {\n          if (idsToHide.newValue.length < idsToHide.oldValue.length) {\n            for (const item of chatBody.children) {\n              if (idsToHide.newValue.filter(user => user.id === item.dataset.peer).length === 0)\n                item.style.display = 'block'\n            }\n          }\n        }\n      })\n    }\n  })\n}\n","const INTERVAL_TIME = 100\n\nexport class UrlController {\n  constructor() {\n    this._changeListeners = []\n    this._interval = null\n    this._url = window.location.href\n  }\n\n  onChange(cb) {\n    this._changeListeners.push(cb)\n    if (this._interval === null)\n      this._createInterval()\n  }\n\n  removeEventListener(cb) {\n    this._changeListeners = this._changeListeners.filter(item => item !== cb)\n    if (this._changeListeners.length === 0)\n      this._clearInterval()\n  }\n\n  _intervalTick() {\n    const currentUrl = window.location.href\n    if (currentUrl !== this.url) {\n      this._broadcast(this.url, currentUrl)\n      this.url = currentUrl\n    }\n  }\n\n  _broadcast(oldUrl, newUrl) {\n    this._changeListeners.forEach(cb => cb(oldUrl, newUrl))\n  }\n\n  _createInterval() {\n    this.interval = setInterval(() => this._intervalTick(), INTERVAL_TIME)\n  }\n\n  _clearInterval() {\n    clearInterval(this.interval)\n    this.interval = null\n  }\n}\n","export function getChatBody() {\n  return document.getElementsByClassName('_im_peer_history im-page-chat-contain')[0]\n}\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, \".mute_tooltip {\\n  position: absolute;\\n  left: -50px;\\n  top: -33px;\\n  display: none;\\n}\\n\\n.mute_tooltip::after {\\n  left: 61px !important;\\n}\\n\\n/* Show the tooltip text when you mouse over the tooltip container */\\n.im-mess--mute:hover .mute_tooltip {\\n  display: block !important;\\n  opacity: 1;\\n}\\n\\n.im-mess--mute {\\n  position: relative;\\n  display: inline-flex;\\n  align-items: center;\\n  justify-content: center;\\n  width: 24px;\\n  height: 24px;\\n  opacity: .5;\\n  color: var(--vkui--color_icon_secondary);\\n}\\n\\n.im-mess--mute:hover {\\n  opacity: 1;\\n}\\n\\n.im-mess--actions {\\n  margin-right: -30px !important;\\n}\", \"\",{\"version\":3,\"sources\":[\"webpack://./src/dom/dom.css\"],\"names\":[],\"mappings\":\"AAAA;EACE,kBAAkB;EAClB,WAAW;EACX,UAAU;EACV,aAAa;AACf;;AAEA;EACE,qBAAqB;AACvB;;AAEA,oEAAoE;AACpE;EACE,yBAAyB;EACzB,UAAU;AACZ;;AAEA;EACE,kBAAkB;EAClB,oBAAoB;EACpB,mBAAmB;EACnB,uBAAuB;EACvB,WAAW;EACX,YAAY;EACZ,WAAW;EACX,wCAAwC;AAC1C;;AAEA;EACE,UAAU;AACZ;;AAEA;EACE,8BAA8B;AAChC\",\"sourcesContent\":[\".mute_tooltip {\\n  position: absolute;\\n  left: -50px;\\n  top: -33px;\\n  display: none;\\n}\\n\\n.mute_tooltip::after {\\n  left: 61px !important;\\n}\\n\\n/* Show the tooltip text when you mouse over the tooltip container */\\n.im-mess--mute:hover .mute_tooltip {\\n  display: block !important;\\n  opacity: 1;\\n}\\n\\n.im-mess--mute {\\n  position: relative;\\n  display: inline-flex;\\n  align-items: center;\\n  justify-content: center;\\n  width: 24px;\\n  height: 24px;\\n  opacity: .5;\\n  color: var(--vkui--color_icon_secondary);\\n}\\n\\n.im-mess--mute:hover {\\n  opacity: 1;\\n}\\n\\n.im-mess--actions {\\n  margin-right: -30px !important;\\n}\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","\"use strict\";\n\n/*\n  MIT License http://www.opensource.org/licenses/mit-license.php\n  Author Tobias Koppers @sokra\n*/\nmodule.exports = function (cssWithMappingToString) {\n  var list = [];\n\n  // return the list of modules as css string\n  list.toString = function toString() {\n    return this.map(function (item) {\n      var content = \"\";\n      var needLayer = typeof item[5] !== \"undefined\";\n      if (item[4]) {\n        content += \"@supports (\".concat(item[4], \") {\");\n      }\n      if (item[2]) {\n        content += \"@media \".concat(item[2], \" {\");\n      }\n      if (needLayer) {\n        content += \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\");\n      }\n      content += cssWithMappingToString(item);\n      if (needLayer) {\n        content += \"}\";\n      }\n      if (item[2]) {\n        content += \"}\";\n      }\n      if (item[4]) {\n        content += \"}\";\n      }\n      return content;\n    }).join(\"\");\n  };\n\n  // import a list of modules into the list\n  list.i = function i(modules, media, dedupe, supports, layer) {\n    if (typeof modules === \"string\") {\n      modules = [[null, modules, undefined]];\n    }\n    var alreadyImportedModules = {};\n    if (dedupe) {\n      for (var k = 0; k < this.length; k++) {\n        var id = this[k][0];\n        if (id != null) {\n          alreadyImportedModules[id] = true;\n        }\n      }\n    }\n    for (var _k = 0; _k < modules.length; _k++) {\n      var item = [].concat(modules[_k]);\n      if (dedupe && alreadyImportedModules[item[0]]) {\n        continue;\n      }\n      if (typeof layer !== \"undefined\") {\n        if (typeof item[5] === \"undefined\") {\n          item[5] = layer;\n        } else {\n          item[1] = \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\").concat(item[1], \"}\");\n          item[5] = layer;\n        }\n      }\n      if (media) {\n        if (!item[2]) {\n          item[2] = media;\n        } else {\n          item[1] = \"@media \".concat(item[2], \" {\").concat(item[1], \"}\");\n          item[2] = media;\n        }\n      }\n      if (supports) {\n        if (!item[4]) {\n          item[4] = \"\".concat(supports);\n        } else {\n          item[1] = \"@supports (\".concat(item[4], \") {\").concat(item[1], \"}\");\n          item[4] = supports;\n        }\n      }\n      list.push(item);\n    }\n  };\n  return list;\n};","\"use strict\";\n\nmodule.exports = function (item) {\n  var content = item[1];\n  var cssMapping = item[3];\n  if (!cssMapping) {\n    return content;\n  }\n  if (typeof btoa === \"function\") {\n    var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(cssMapping))));\n    var data = \"sourceMappingURL=data:application/json;charset=utf-8;base64,\".concat(base64);\n    var sourceMapping = \"/*# \".concat(data, \" */\");\n    return [content].concat([sourceMapping]).join(\"\\n\");\n  }\n  return [content].join(\"\\n\");\n};","export default \"<svg \\n  xmlns=\\\"http://www.w3.org/2000/svg\\\" \\n  width=\\\"16\\\" \\n  height=\\\"16\\\" \\n  fill=\\\"currentColor\\\" \\n  viewBox=\\\"2 1 13 13\\\"\\n>\\n  <path d=\\\"M4.69 5.5 11 11.8v1.7c0 .3-.23.47-.49.5l-3.63-3.5H4a1 1 0 0 1-1-1v-3a1 1 0 0 1 1-1h.69Zm.77-2.85 2.2 2.19L10.5 2.5c.27.02.49.2.49.48v5.2l2.6 2.6a.75.75 0 0 1-1.06 1.06L4.4 3.71a.75.75 0 0 1 1.06-1.06Z\\\"></path>\\n</svg>\\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;","\"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};","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.nc = undefined;","import './dom.css'\nimport { UrlController } from '../utils/Url'\nimport { createTryToInitInterval, hideExistingMessages, tryToInitControls } from './controls'\nimport { addNewMessageEventListener, returnMessagesEventListener } from './hide_element'\n\nfunction init() {\n  const url = new UrlController()\n  url.onChange(() => {\n    if (tryToInitControls()) {\n      createTryToInitInterval()\n      addNewMessageEventListener()\n      returnMessagesEventListener()\n      chrome.storage.sync.get('isExtensionOn', (data) => {\n        if (data.isExtensionOn)\n          hideExistingMessages()\n      })\n    }\n  })\n}\n\ninit()\n"],"names":["getChatBody","muteSvg","muteBtnHTML","id","element","document","createElement","setAttribute","concat","innerHTML","tryToAddControls","target","className","message","parentElement","addControlButton","addMuteButton","actionArea","senderId","muteButton","appendChild","style","visibility","addActionAreaEvents","actionsArea","addEventListener","event","getElementsByClassName","setIdToHideHandle","clickedId","substring","clickedName","children","textContent","chrome","storage","sync","get","data","idsToHide","filter","user","length","push","name","set","isExtensionOn","hideExistingMessages","chatBody","_iterator","_createForOfIteratorHelper","_step","_loop","item","value","dataset","peer","display","s","n","done","err","e","f","createTryToInitInterval","controlsInterval","setInterval","tryToInitControls","clearInterval","classList","contains","lastChild","muteBtn","status","_iterator2","_step2","includes","messages","_iterator3","_step3","addNewMessageEventListener","newMessageHandler","returnMessagesEventListener","onChanged","addListener","changes","newValue","oldValue","INTERVAL_TIME","UrlController","_classCallCheck","_changeListeners","_interval","_url","window","location","href","_createClass","key","onChange","cb","_createInterval","removeEventListener","_clearInterval","_intervalTick","currentUrl","url","_broadcast","oldUrl","newUrl","forEach","_this","interval","init"],"sourceRoot":""}
|