// ==UserScript==
// @name Blum Autoclicker
// @version 2.4
// @namespace Violentmonkey Scripts
// @author mudachyo
// @match https://telegram.blum.codes/*
// @grant none
// @icon https://cdn.prod.website-files.com/65b6a1a4a0e2af577bccce96/65ba99c1616e21b24009b86c_blum-256.png
// @homepage https://github.com/mudachyo/Blum
// @description blumgame
// ==/UserScript==
let GAME_SETTINGS = {
minBombHits: Math.floor(Math.random() * 2),
minIceHits: Math.floor(Math.random() * 2) + 2,
flowerSkipPercentage: Math.floor(Math.random() * 11) + 15,
minDelayMs: 500,
maxDelayMs: 999,
autoClickPlay: false,
dogsProbability: (98 + Math.random()) / 100
};
let isGamePaused = false;
try {
let gameStats = {
score: 0,
bombHits: 0,
iceHits: 0,
dogsHits: 0,
flowersSkipped: 0,
isGameOver: false,
};
const originalArrayPush = Array.prototype.push;
Array.prototype.push = function(...items) {
items.forEach(item => handleGameElement(item));
return originalArrayPush.apply(this, items);
};
function handleGameElement(item) {
if (!item || !item.asset) return;
const {
assetType
} = item.asset;
switch (assetType) {
case "CLOVER":
processFlower(item);
break;
case "BOMB":
processBomb(item);
break;
case "FREEZE":
processIce(item);
break;
case "DOGS":
processDogs(item);
break;
}
}
function processFlower(item) {
const shouldSkip = Math.random() < (GAME_SETTINGS.flowerSkipPercentage / 100);
if (shouldSkip) {
gameStats.flowersSkipped++;
} else {
gameStats.score++;
clickElement(item);
}
}
function processBomb(item) {
if (gameStats.bombHits < GAME_SETTINGS.minBombHits) {
gameStats.score = 0;
clickElement(item);
gameStats.bombHits++;
}
}
function processIce(item) {
if (gameStats.iceHits < GAME_SETTINGS.minIceHits) {
clickElement(item);
gameStats.iceHits++;
}
}
function processDogs(item) {
if (Math.random() < GAME_SETTINGS.dogsProbability) {
clickElement(item);
gameStats.dogsHits++;
}
}
function clickElement(item) {
const createEvent = (type, EventClass) => new EventClass(type, {
bubbles: true,
cancelable: true,
pointerId: 1,
isPrimary: true,
pressure: type === 'pointerdown' ? 0.5 : 0
});
setTimeout(() => {
if (typeof item.onClick === 'function') {
if (item.element) {
['pointerdown', 'mousedown', 'pointerup', 'mouseup', 'click'].forEach(type => {
item.element.dispatchEvent(createEvent(type, type.startsWith('pointer') ? PointerEvent : MouseEvent));
});
}
item.onClick(item);
}
item.isExplosion = true;
item.addedAt = performance.now();
}, getClickDelay());
}
// Функция для расчета задержки между кликами
function getClickDelay() {
const minDelay = GAME_SETTINGS.minDelayMs || 500;
const maxDelay = GAME_SETTINGS.maxDelayMs || 1000;
return Math.random() * (maxDelay - minDelay) + minDelay;
}
function checkGameCompletion() {
const rewardElement = document.querySelector('#app > div > div > div.content > div.reward');
if (rewardElement && !gameStats.isGameOver) {
gameStats.isGameOver = true;
resetGameStats();
}
}
function resetGameStats() {
gameStats = {
score: 0,
bombHits: 0,
iceHits: 0,
dogsHits: 0,
flowersSkipped: 0,
isGameOver: false,
};
}
function getNewGameDelay() {
return Math.floor(Math.random() * (GAME_SETTINGS.maxDelayMs - GAME_SETTINGS.minDelayMs + 1) + GAME_SETTINGS.minDelayMs);
}
function checkAndClickPlayButton() {
const playButtons = document.querySelectorAll('button.kit-button.is-large.is-primary, a.play-btn[href="/game"], button.kit-button.is-large.is-primary');
playButtons.forEach(button => {
if (!isGamePaused && GAME_SETTINGS.autoClickPlay && (/Play/.test(button.textContent) || /Continue/.test(button.textContent))) {
setTimeout(() => {
button.click();
gameStats.isGameOver = false;
}, getNewGameDelay());
}
});
}
function continuousPlayButtonCheck() {
checkAndClickPlayButton();
setTimeout(continuousPlayButtonCheck, 1000);
}
const observer = new MutationObserver(mutations => {
for (const mutation of mutations) {
if (mutation.type === 'childList') {
checkGameCompletion();
}
}
});
const appElement = document.querySelector('#app');
if (appElement) {
observer.observe(appElement, {
childList: true,
subtree: true
});
}
continuousPlayButtonCheck();
const settingsMenu = document.createElement('div');
settingsMenu.className = 'settings-menu';
settingsMenu.style.display = 'none';
const menuTitle = document.createElement('h3');
menuTitle.className = 'settings-title';
menuTitle.textContent = 'Blum Autoclicker';
const closeButton = document.createElement('button');
closeButton.className = 'settings-close-button';
closeButton.textContent = '×';
closeButton.onclick = () => {
settingsMenu.style.display = 'none';
};
menuTitle.appendChild(closeButton);
settingsMenu.appendChild(menuTitle);
function updateSettingsMenu() {
document.getElementById('flowerSkipPercentage').value = GAME_SETTINGS.flowerSkipPercentage;
document.getElementById('flowerSkipPercentageDisplay').textContent = GAME_SETTINGS.flowerSkipPercentage;
document.getElementById('minIceHits').value = GAME_SETTINGS.minIceHits;
document.getElementById('minIceHitsDisplay').textContent = GAME_SETTINGS.minIceHits;
document.getElementById('minBombHits').value = GAME_SETTINGS.minBombHits;
document.getElementById('minBombHitsDisplay').textContent = GAME_SETTINGS.minBombHits;
document.getElementById('minDelayMs').value = GAME_SETTINGS.minDelayMs;
document.getElementById('minDelayMsDisplay').textContent = GAME_SETTINGS.minDelayMs;
document.getElementById('maxDelayMs').value = GAME_SETTINGS.maxDelayMs;
document.getElementById('maxDelayMsDisplay').textContent = GAME_SETTINGS.maxDelayMs;
document.getElementById('autoClickPlay').checked = GAME_SETTINGS.autoClickPlay;
}
settingsMenu.appendChild(createSettingElement('Flower Skip (%)', 'flowerSkipPercentage', 'range', 0, 100, 1,
'EN: Percentage probability of skipping a flower.<br>' +
'RU: Вероятность пропуска цветка в процентах.'));
settingsMenu.appendChild(createSettingElement('Min Freeze Hits', 'minIceHits', 'range', 1, 10, 1,
'EN: Minimum number of clicks per freeze.<br>' +
'RU: Минимальное количество кликов на заморозку.'));
settingsMenu.appendChild(createSettingElement('Min Bomb Hits', 'minBombHits', 'range', 0, 10, 1,
'EN: Minimum number of clicks per bomb.<br>' +
'RU: Минимальное количество кликов на бомбу.'));
settingsMenu.appendChild(createSettingElement('Min Delay (ms)', 'minDelayMs', 'range', 10, 10000, 10,
'EN: Minimum delay between clicks.<br>' +
'RU: Минимальная задержка между кликами.'));
settingsMenu.appendChild(createSettingElement('Max Delay (ms)', 'maxDelayMs', 'range', 10, 10000, 10,
'EN: Maximum delay between clicks.<br>' +
'RU: Максимальная задержка между кликами.'));
settingsMenu.appendChild(createSettingElement('Auto Click Play', 'autoClickPlay', 'checkbox', null, null, null,
'EN: Automatically start the next game at the end of.<br>' +
'RU: Автоматически начинать следующую игру по окончании.'));
const pauseResumeButton = document.createElement('button');
pauseResumeButton.textContent = 'Pause';
pauseResumeButton.className = 'pause-resume-btn';
pauseResumeButton.onclick = toggleGamePause;
settingsMenu.appendChild(pauseResumeButton);
const socialButtons = document.createElement('div');
socialButtons.className = 'social-buttons';
const githubButton = document.createElement('a');
githubButton.href = 'https://github.com/mudachyo/Blum';
githubButton.target = '_blank';
githubButton.className = 'social-button';
githubButton.innerHTML = '<img src="">GitHub';
socialButtons.appendChild(githubButton);
const telegramButton = document.createElement('a');
telegramButton.href = 'https://t.me/shopalenka';
telegramButton.target = '_blank';
telegramButton.className = 'social-button';
telegramButton.innerHTML = '<img src="">Telegram Channel';
socialButtons.appendChild(telegramButton);
const donateButton = document.createElement('a');
donateButton.href = 'https://mudachyo.codes/donate/';
donateButton.target = '_blank';
donateButton.className = 'social-button';
donateButton.innerHTML = '<img src="">Donate';
socialButtons.appendChild(donateButton);
settingsMenu.appendChild(socialButtons);
document.body.appendChild(settingsMenu);
const settingsButton = document.createElement('button');
settingsButton.className = 'settings-button';
settingsButton.textContent = '⚙️';
settingsButton.onclick = () => {
settingsMenu.style.display = settingsMenu.style.display === 'block' ? 'none' : 'block';
};
document.body.appendChild(settingsButton);
const style = document.createElement('style');
style.textContent = `
.settings-menu {
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
background-color: rgba(40, 44, 52, 0.95);
border-radius: 8px;
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2);
color: #abb2bf;
font-family: 'Arial', sans-serif;
z-index: 10000;
padding: 20px;
width: 300px;
}
.settings-title {
color: #61afef;
font-size: 18px;
font-weight: bold;
margin-bottom: 15px;
display: flex;
align-items: center;
justify-content: space-between;
}
.settings-close-button {
background: none;
border: none;
color: #e06c75;
font-size: 20px;
cursor: pointer;
padding: 0;
}
.setting-item {
margin-bottom: 12px;
}
.setting-label {
display: flex;
align-items: center;
margin-bottom: 4px;
}
.setting-label-text {
color: #e5c07b;
margin-right: 5px;
}
.help-icon {
cursor: help;
display: inline-flex;
align-items: center;
justify-content: center;
width: 14px;
height: 14px;
border-radius: 50%;
background-color: #61afef;
color: #282c34;
font-size: 10px;
font-weight: bold;
}
.setting-input {
display: flex;
align-items: center;
}
.setting-slider {
flex-grow: 1;
margin-right: 8px;
}
.setting-value {
min-width: 30px;
text-align: right;
font-size: 11px;
}
.tooltip {
position: relative;
}
.tooltip .tooltiptext {
visibility: hidden;
width: 200px;
background-color: #4b5263;
color: #fff;
text-align: center;
border-radius: 6px;
padding: 5px;
position: absolute;
z-index: 1;
bottom: 125%;
left: 50%;
margin-left: -100px;
opacity: 0;
transition: opacity 0.3s;
font-size: 11px;
box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}
.tooltip:hover .tooltiptext {
visibility: visible;
opacity: 1;
}
.pause-resume-btn {
display: block;
width: calc(100% - 10px);
padding: 8px;
margin: 15px 5px;
background-color: #98c379;
color: #282c34;
border: none;
border-radius: 4px;
cursor: pointer;
font-weight: bold;
font-size: 14px;
transition: background-color 0.3s;
}
.pause-resume-btn:hover {
background-color: #7cb668;
}
.social-buttons {
margin-top: 15px;
display: flex;
justify-content: space-between;
white-space: nowrap;
}
.social-button {
display: inline-flex;
align-items: center;
padding: 5px 8px;
border-radius: 4px;
background-color: #282c34;
color: #abb2bf;
text-decoration: none;
font-size: 12px;
transition: background-color 0.3s;
}
.social-button:hover {
background-color: #4b5263;
}
.social-button img {
width: 16px;
height: 16px;
margin-right: 5px;
}
.settings-button {
position: fixed;
bottom: 20px;
right: 20px;
background-color: rgba(36, 146, 255, 0.8);
color: #fff;
border: none;
border-radius: 50%;
width: 40px;
height: 40px;
font-size: 18px;
cursor: pointer;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
z-index: 9999;
}
`;
document.head.appendChild(style);
function createSettingElement(label, id, type, min, max, step, tooltipText) {
const container = document.createElement('div');
container.className = 'setting-item';
const labelContainer = document.createElement('div');
labelContainer.className = 'setting-label';
const labelElement = document.createElement('span');
labelElement.className = 'setting-label-text';
labelElement.textContent = label;
const helpIcon = document.createElement('span');
helpIcon.textContent = '?';
helpIcon.className = 'help-icon tooltip';
const tooltipSpan = document.createElement('span');
tooltipSpan.className = 'tooltiptext';
tooltipSpan.innerHTML = tooltipText;
helpIcon.appendChild(tooltipSpan);
labelContainer.appendChild(labelElement);
labelContainer.appendChild(helpIcon);
const inputContainer = document.createElement('div');
inputContainer.className = 'setting-input';
function AutoClaimAndStart() {
setInterval(() => {
const claimButton = document.querySelector('button.kit-button.is-large.is-drop.is-fill.button.is-done');
const startFarmingButton = document.querySelector('button.kit-button.is-large.is-primary.is-fill.button');
const continueButton = document.querySelector('button.kit-button.is-large.is-primary.is-fill.btn');
if (claimButton) {
claimButton.click();
} else if (startFarmingButton) {
startFarmingButton.click();
} else if (continueButton) {
continueButton.click();
}
}, Math.floor(Math.random() * 5000) + 5000);
}
AutoClaimAndStart();
let input;
if (type === 'checkbox') {
input = document.createElement('input');
input.type = 'checkbox';
input.id = id;
input.checked = GAME_SETTINGS[id];
input.addEventListener('change', (e) => {
GAME_SETTINGS[id] = e.target.checked;
saveSettings();
});
inputContainer.appendChild(input);
} else {
input = document.createElement('input');
input.type = type;
input.id = id;
input.min = min;
input.max = max;
input.step = step;
input.value = GAME_SETTINGS[id];
input.className = 'setting-slider';
const valueDisplay = document.createElement('span');
valueDisplay.id = `${id}Display`;
valueDisplay.textContent = GAME_SETTINGS[id];
valueDisplay.className = 'setting-value';
input.addEventListener('input', (e) => {
GAME_SETTINGS[id] = parseFloat(e.target.value);
valueDisplay.textContent = e.target.value;
saveSettings();
});
inputContainer.appendChild(input);
inputContainer.appendChild(valueDisplay);
}
container.appendChild(labelContainer);
container.appendChild(inputContainer);
return container;
}
function saveSettings() {
localStorage.setItem('BlumAutoclickerSettings', JSON.stringify(GAME_SETTINGS));
}
function loadSettings() {
const savedSettings = localStorage.getItem('BlumAutoclickerSettings');
if (savedSettings) {
const parsedSettings = JSON.parse(savedSettings);
GAME_SETTINGS = {
...GAME_SETTINGS,
...parsedSettings
};
}
}
loadSettings();
updateSettingsMenu();
function toggleGamePause() {
isGamePaused = !isGamePaused;
pauseResumeButton.textContent = isGamePaused ? 'Resume' : 'Pause';
pauseResumeButton.style.backgroundColor = isGamePaused ? '#e5c07b' : '#98c379';
}
} catch (e) {
console.error("Blum Autoclicker error:", e);
}