0
0
mirror of https://github.com/Maks1mS/userscripts.git synced 2025-10-13 22:42:38 +03:00

Compare commits

..

11 Commits

Author SHA1 Message Date
becff1ef68 Merge branch 'main' of https://github.com/Maks1mS/userscripts 2024-06-25 21:26:29 +03:00
5f002ba7f7 [FreeOzonDPR] update to 0.2.1
replace delivery in checkout
2024-06-25 21:26:26 +03:00
KaMZeSs
9cad4d315b [VKBigChatStickers] fix increasing stickers
---------

Co-authored-by: Maxim Slipenko <no-reply@maxim.slipenko.com>
2024-06-25 12:32:42 +03:00
KaMZeSs
cf8ed72d1a [VKBigChatStickers] update to 0.3
- update to the sticker icon position (#3)
2024-06-25 10:57:40 +03:00
38b3fe10be [SteamPriceConverter] update to 0.7.1
add steamcommunity (closes #2)
2024-06-24 08:48:02 +03:00
91e5166b44 [SteamPriceConverter] update to 0.7
fix USD
2024-06-23 14:46:43 +03:00
82ea415171 [SteamPriceConverter] update to 0.6
replace prices when body updates
2024-06-23 10:19:20 +03:00
fbe2e6e830 [SteamPriceConverter] update to 0.5
replace only price in textContent
2024-06-22 23:55:35 +03:00
5de1a557f1 [SteamPriceConverter] update to 0.4
fix some bugs
2024-06-22 23:29:56 +03:00
KaMZeSs
db9d93407d [SteamPriceConverter] update to 0.3
- add timeout and source price viewing (#1)
2024-06-22 23:23:29 +03:00
32a4239fe4 [FreeOzonDPR] update to 0.2 2024-06-22 22:25:01 +03:00
3 changed files with 145 additions and 50 deletions

View File

@@ -1,7 +1,7 @@
// ==UserScript==
// @name БЕСПЛАТНЫЕ ПВЗ ОЗОН
// @namespace https://github.com/Maks1mS/userscripts
// @version 0.1
// @version 0.2.1
// @description Заменяет партнерские ПВЗ на понятные адреса
// @author Maxim Slipenko
// @match https://www.ozon.ru/*
@@ -104,13 +104,12 @@
}
function updateInfoALL() {
console.log('updateall!');
const headerAddress = qs('[data-widget="addressBookBarWeb"] .tsBody400Small');
const commonAddressBook = qsa('[data-widget="commonAddressBook"] .tsBody500Medium');
const delivery = qsa('[data-widget="orderDeliveryDetails"] .tsBody500Medium');
const delivery2 = qsa('[data-widget="rfbsAddressInfo"] .tsBody500Medium');
const elements = [headerAddress, ...commonAddressBook, ...delivery];
const elements = [headerAddress, ...commonAddressBook, ...delivery, ...delivery2];
elements.forEach(handleElement);
}
@@ -120,41 +119,52 @@
updateInfoALL();
}
async function onSelectorAdd(targetNode, selector, callback) {
function check(s) {
const r = qs(s);
if (r) {
callback(r);
}
}
function checkSelector() {
if (Array.isArray(selector)) {
selector.forEach(check);
}
check(selector);
}
checkSelector();
function handle(mutationsList) {
for (let mutation of mutationsList) {
if (mutation.type === 'childList') {
checkSelector();
}
}
}
addObserver(targetNode, handle, { childList: true, subtree: true });
}
let called = false;
function fullExecute() {
if (called) return;
called = true;
updateInfoPeriodically(5000);
function handleNewElement(mutationsList) {
for (let mutation of mutationsList) {
if (mutation.type === 'childList') {
mutation.addedNodes.forEach(node => {
if (node.nodeType === Node.ELEMENT_NODE && node.classList.contains('vue-portal-target')) {
setTimeout(() => {
updateInfoALL();
}, 1000);
}
});
}
}
}
const observer = new MutationObserver(handleNewElement);
const targetNode = document.body;
const config = { childList: true, subtree: true };
observer.observe(targetNode, config);
onSelectorAdd(document.body, [
'[data-widget="commonAddressBook"]',
], updateInfoALL);
}
window.addEventListener('popstate', fullExecute);
window.addEventListener('load', fullExecute);
document.addEventListener('DOMContentLoaded', fullExecute);
setTimeout(fullExecute, 2500);
if (document.readyState == "complete" ||
document.readyState == "loaded" ||
document.readyState == "interactive"
) {
fullExecute();
}
}
main();

View File

@@ -1,16 +1,17 @@
// ==UserScript==
// @name Steam Price Converter
// @namespace https://github.com/Maks1mS/userscripts
// @version 0.2
// @version 0.7.1
// @description Converts prices to rubles
// @author Maxim Slipenko
// @match https://store.steampowered.com/*
// @match https://steamcommunity.com/*
// @icon https://www.google.com/s2/favicons?sz=64&domain=steampowered.com
// @grant GM_xmlhttpRequest
// @grant GM_registerMenuCommand
// ==/UserScript==
(function() {
(function () {
'use strict';
const SYMBOL_TO_CODE_MAPPING = {
@@ -23,12 +24,15 @@
source_symbol: undefined
}
const delay = (ms) =>
new Promise(resolve => setTimeout(resolve, ms));
async function getRates() {
const arr = await new Promise((resolve, reject) => {
GM_xmlhttpRequest({
method: 'GET',
url: 'https://www.cbr-xml-daily.ru/daily_utf8.xml',
onload: function(res) {
onload: function (res) {
const valutes = res.responseXML.getElementsByTagName('Valute');
resolve([...valutes].map((valute) => {
const charCode = valute.getElementsByTagName('CharCode')[0].textContent;
@@ -54,6 +58,29 @@
return SYMBOL_TO_CODE_MAPPING[state.source_symbol];
}
const observers = new WeakMap();
function addObserver(element, callback, config = { childList: true }) {
if (element && !observers.has(element)) {
const observer = new MutationObserver(callback);
observer.observe(element, config);
observers.set(element, observer);
}
}
function qs(...args) {
return document.querySelector(...args);
}
function debounce(callback, delay) {
let timeout;
return function (...args) {
clearTimeout(timeout);
timeout = setTimeout(() => {
callback(...args);
}, delay);
};
}
async function main() {
const rates = await getRates();
const source_valute = getCurrentValute();
@@ -62,22 +89,76 @@
return;
}
const convert = (n) => +(n * rates[source_valute].value).toFixed(2);
replace(convert);
// await delay(75);
GM_registerMenuCommand("update", () => replace(convert), "u");
const convert = (n) => +(n * rates[source_valute].value).toFixed(2);
const execute = () => {
replace(convert);
}
const config = { childList: true, subtree: true };
function handle(mutationsList, observer) {
observer.disconnect();
execute();
observer.observe(document.body, config);
}
const debouncedCallback = debounce(handle, 300);
addObserver(document.body, debouncedCallback, config);
window.addEventListener('popstate', execute);
window.addEventListener('load', execute);
document.addEventListener('DOMContentLoaded', execute);
if (document.readyState == "complete" ||
document.readyState == "loaded" ||
document.readyState == "interactive"
) {
execute();
}
// GM_registerMenuCommand("update", () => replace(convert), "u");
}
function replace(convert) {
let r = document.evaluate(`//text()[contains(., \"${state.source_symbol}\")]`,document, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
let xpath = `//text()[contains(., \"${state.source_symbol}\") and not(ancestor::*[@data-converted]) and not(ancestor::script)]`;
let r = document.evaluate(xpath, document, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
for (let i = 0; i < r.snapshotLength; i++) {
let n = r.snapshotItem(i);
const value = parseFloat(n.textContent.replace(" ", "").replace(',', '.'))
n.replaceWith(`${convert(value)}`);
console.log(n)
let textContent = n.textContent;
let regex = new RegExp(`(\\${state.source_symbol}\\s*[0-9\\s]+[.,]?[0-9]*(?:USD)?|[0-9\\s]*[.,]?[0-9]+\\s*\\${state.source_symbol})`, 'g');
let newContent = textContent.replace(regex, (match) => {
let value;
let originalValue;
originalValue = match.replace(state.source_symbol, '').replace(' ', '').replace(',', '.').trim();
value = parseFloat(originalValue);
let convertedValue = convert(value);
let formattedConvertedValue;
let formattedOriginalValue;
if (match.trim().startsWith(state.source_symbol)) {
formattedOriginalValue = `${state.source_symbol}${originalValue}`;
} else {
formattedOriginalValue = `${originalValue}${state.source_symbol}`;
}
formattedConvertedValue = `${convertedValue}`;
return `${formattedConvertedValue} / ${formattedOriginalValue}`;
});
let newNode = document.createTextNode(newContent);
n.parentNode.setAttribute('data-converted', 'true');
n.parentNode.replaceChild(newNode, n);
// console.log(newNode);
}
}
main();
})();

View File

@@ -1,7 +1,7 @@
// ==UserScript==
// @name VK Big Chat Stickers
// @namespace https://github.com/Maks1mS/userscripts
// @version 0.2
// @version 0.3
// @description Increases size of chat stickers
// @author Maxim Slipenko
// @match https://vk.com/*
@@ -9,14 +9,18 @@
// @grant GM_addStyle
// ==/UserScript==
(function() {
(function () {
'use strict';
const style = `
img.StickerUGC {
.sticker_img_wrapper:has(.StickerUGC) {
width: 256px;
height: 256px;
}
img.StickerUGC {
height: 100%;
width: 100%;
}
.StickersEmojiKeyboard-module__in--GCR5_:has(.StickersKeyboardGroupItem-module__in--CKjkC.StickersKeyboardGroupItem-module__inActive--iqstp > div[aria-label="Стикеры чата"]) .StickersKeyboard-module__keyboard--HhSGu.View-module__panel--WNKKi.View-module__panelSwitched--hg3jP {
--stickers-columns: 2 !important;