您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Таймеры для гильдии охотников и наёмников
当前为
// ==UserScript== // @name [HWM] GuildTimersOnMain // @namespace [HWM] GuildTimersOnMain // @version 0.2.0 // @description Таймеры для гильдии охотников и наёмников // @author Komdosh // @include http*://*.heroeswm.ru/home.php* // @include http*://*.heroeswm.ru/map.php* // @include http*://*.heroeswm.ru/mercenary_guild.php* // @grant none // @license MIT // ==/UserScript== const GUILDS_INFO_MERCENARY = 'GUILDS_INFO_MERCENARY'; const GUILDS_INFO_MERCENARY_IS_SHOWN = 'GUILDS_INFO_MERCENARY_IS_SHOWN'; const GUILDS_INFO_HUNTER = 'GUILDS_INFO_HUNTER'; const GUILDS_INFO_HUNTER_IS_SHOWN = 'GUILDS_INFO_HUNTER_IS_SHOWN'; const GUILDS_INFO_THIEF = 'GUILDS_INFO_THIEF'; const GUILDS_INFO_THIEF_IS_SHOWN = 'GUILDS_INFO_THIEF_IS_SHOWN'; if (/map.php/.test(location.href)) { const hunterInfo = getWithExpiry(GUILDS_INFO_HUNTER); if (hunterInfo != null && hunterInfo === '-1') { localStorage.removeItem(GUILDS_INFO_HUNTER); } const thiefInfo = getWithExpiry(GUILDS_INFO_THIEF); if (thiefInfo != null && thiefInfo === '-1') { localStorage.removeItem(GUILDS_INFO_THIEF); } return; } else if (/mercenary_guild.php/.test(location.href)) { const mercenaryInfo = getWithExpiry(GUILDS_INFO_MERCENARY); if (mercenaryInfo != null && mercenaryInfo === '-1') { localStorage.removeItem(GUILDS_INFO_MERCENARY); } return; } const userInfo = getUserInfo(); const guildsInfoDiv = document.createElement('div'); guildsInfoDiv.className += "home_container_block"; guildsInfoDiv.style = "align-items: left;"; const guildsInfoHeader = document.createElement('div'); guildsInfoHeader.className += "global_container_block_header global_a_hover"; guildsInfoHeader.innerHTML = 'Таймеры'; guildsInfoDiv.append(guildsInfoHeader); const guildsInfoContentDiv = document.createElement('div'); guildsInfoContentDiv.className += "home_inside_margins global_a_hover"; guildsInfoDiv.append(guildsInfoContentDiv); const workerGuild = document.querySelector(".home_work_block"); workerGuild.after(guildsInfoDiv); const loading = document.createElement('span'); loading.innerText = 'Данные обновляются...'; guildsInfoContentDiv.append(loading); requestHunterInfo(); requestMercenaryInfo(); requestThiefInfo(userInfo.id); //*************************************************************************** function requestHunterInfo() { request('hunter', 'Охота будет доступна через ', "/map.php", GUILDS_INFO_HUNTER, 'ГО', '<a href="map.php" style="text-decoration:underline">Новая охота</a>', 'Охотники зовут на помощь', (respDoc, timerDiv) => { const script = document.querySelector('#map_right_block_inside').getElementsByTagName('script')[0]; const scriptDeltaText = script.text.match(/Delta2 = (\d+)/); if (scriptDeltaText == null) { return 0; } else { return parseInt(scriptDeltaText[1]); } }); } //*************************************************************************** function requestMercenaryInfo() { request('mercenary', 'Новое задание через ', "/mercenary_guild.php", GUILDS_INFO_MERCENARY, 'ГН', '<a href="mercenary_guild.php" style="text-decoration:underline">Новое задание</a>', 'Наёмникам требуется герой!', (respDoc, timerDiv) => { const taskMessageDiv = respDoc.querySelector('table:not([align="center"])').querySelector('table:not([align="center"], [class="wbwhite"])'); if (taskMessageDiv == null) { return 0; } else { const taskMessage = taskMessageDiv.querySelector('td').innerText; return parseInt(taskMessage.split('\u0447\u0435\u0440\u0435\u0437 ')[1].split(' ')[0]) * 60; } }); } //*************************************************************************** function requestThiefInfo(userId) { request('thief', 'Новое задание через ', `/pl_warlog.php?id=${userId}`, GUILDS_INFO_THIEF, 'ГВ', '<a href="map.php" style="text-decoration:underline">Новое задание</a>', 'Воры замышляют новое нападение!', (respDoc, timerDiv) => { const battles = respDoc.querySelector('div[class="global_a_hover"]').innerHTML.split('br'); let nextTime = 1000 * 60 * 60; if (isPremium()) { nextTime *= 0.7; } for (const battle of battles) { if (/\u041A\u0430\u0440\u0430\u0432\u0430\u043D/.test(battle)) { // Караван if (/<b>\u041A\u0430\u0440\u0430\u0432\u0430\u043D/.test(battle)) { let battleDate = battles[0].split('>')[1].split('<')[0]; const battleDateSplit = battleDate.split('-'); battleDate = battleDateSplit[1] + '-' + battleDateSplit[0] + '-' + battleDateSplit[2]; const thiefDateTime = new Date(battleDate); return Math.floor(((thiefDateTime.getTime() + nextTime) - Date.now()) / 1000); } else { return 0; } } } return 0; }); } function request(domId, taskHtml, link, localStorageName, notifyMeLinkName, newTaskInstantlyDom, notifyText, processor) { const timerDiv = document.createElement('div'); timerDiv.id = domId; guildsInfoContentDiv.append(timerDiv); const expiration = getWithExpiry(localStorageName); const delay = Math.floor((expiration?expiration:0 - Date.now()) / 1000); const notifyMeLink = document.createElement('a'); notifyMeLink.style = 'cursor: pointer'; notifyMeLink.text = notifyMeLinkName; let isNotify = localStorage.getItem(localStorageName + '_SETTINGS') === 'true'; let notificationCancellation = null; notificationCancellation = createCancellableNotification(isNotify, notificationCancellation, notifyMeLink, 1, notifyText, localStorageName, `<b>${notifyMeLinkName}</b>: `, `${notifyMeLinkName}: `); notifyMeLink.onclick = () => { isNotify = !isNotify; notificationCancellation = createCancellableNotification(isNotify, notificationCancellation, notifyMeLink, delay, notifyText, localStorageName, `<b>${notifyMeLinkName}</b>: `, `${notifyMeLinkName}: `); localStorage.setItem(localStorageName + '_SETTINGS', isNotify); }; const wrapper = document.createElement('span'); wrapper.append(notifyMeLink); if (expiration != null) { if (loading != null) { loading.remove(); } const delay = Math.floor((expiration - Date.now()) / 1000); if (expiration === '-1') { timerDiv.append(createElementFromTextAndAppend(wrapper, newTaskInstantlyDom)); return; } localStorage.setItem(localStorageName+'_IS_SHOWN', 'false'); initTimer(delay, timerDiv, createElementFromTextAndAppend(wrapper, taskHtml)); return; } const xhr = new XMLHttpRequest(); xhr.open('GET', encodeURI(link)); xhr.overrideMimeType('text/xml; charset=windows-1251'); xhr.onload = function () { if (xhr.status === 200) { const div = document.createElement('div'); div.id = 'kom-' + domId; div.style.display = 'none'; div.innerHTML = xhr.responseText; document.getElementsByTagName('body')[0].appendChild(div); const respDoc = document.getElementById('kom-' + domId); if (loading != null) { loading.remove(); } const delta = processor(respDoc, timerDiv); if (delta > 0) { const expiration = Date.now() + delta * 1000; setWithExpiry(localStorageName, expiration, expiration); localStorage.setItem(localStorageName+'_IS_SHOWN', 'false'); initTimer(delta, timerDiv, createElementFromTextAndAppend(wrapper, taskHtml)); } else { setWithExpiry(localStorageName, '-1', Date.now() + 60 * 60 * 1000); timerDiv.append(createElementFromTextAndAppend(wrapper, newTaskInstantlyDom)); } respDoc.remove(); } else { console.log('Request failed. Returned status of ' + xhr.status); } }; xhr.send(); } //*************************************************************************** function setWithExpiry(key, value, expirationTime) { const item = { value: value, expiry: expirationTime, } localStorage.setItem(key, JSON.stringify(item)) } //*************************************************************************** function getWithExpiry(key) { const itemStr = localStorage.getItem(key) // if the item doesn't exist, return null if (!itemStr) { return null } const item = JSON.parse(itemStr) const now = new Date() // compare the expiry time of the item with the current time if (now.getTime() > item.expiry) { // If the item is expired, delete the item from storage // and return null localStorage.removeItem(key) return null } return item.value } //*************************************************************************** function initTimer(Delta, timerDiv, html) { const timeSpan = document.createElement('span'); html.append(timeSpan); function print_time(t) { if (t < 0) t = 0; const min = Math.floor(t / 60); const sec = t % 60; let s = ''; if (min) s = min + ' ' + 'мин. '; s = s + sec + ' ' + 'с. '; timeSpan.innerText = ' '+s; if(timerDiv.firstChild != null){ timerDiv.replaceChild(html,timerDiv.firstChild); } else { timerDiv.append(html); } } const Refresh2 = () => { if (Timer2 >= 0) clearTimeout(Timer2); Delta = Delta - 1; print_time(Delta); if (Delta >= 0) Timer2 = setTimeout(Refresh2, 1000); } let Timer2 = setTimeout(Refresh2, 1000); print_time(Delta); } //******************* function getUserInfo() { const infoLink = document.querySelector('center>a[href^=pl_info]'); const infoLinkValues = infoLink.href.split("id="); return {id: infoLinkValues[infoLinkValues.length - 1], name: infoLink.innerText}; } //******************* function isPremium() { return document.querySelector('a[href="shop.php?cat=potions#vip"]') != null; } //*************************************************************************** function createCancellableNotification(isNotify, notificationCancellation, notifyMeLink, delay, text, localStorageNamePrefix, nameHtmlOn, nameHtmlOff) { if (isNotify) { notifyMeLink.innerHTML = nameHtmlOn; notifyMeLink.title = 'Уведомление: включено'; notificationCancellation = notifyAfter(delay, text, localStorageNamePrefix); } else { notifyMeLink.innerHTML = nameHtmlOff; notifyMeLink.title = 'Уведомление: выключено'; if (notificationCancellation != null) { clearTimeout(notificationCancellation); } } return notificationCancellation; } //*************************************************************************** function notifyAfter(delay, text, localStorageNamePrefix) { if(localStorage.getItem(localStorageNamePrefix + '_IS_SHOWN') != 'false'){ return ; } var notify = alert; const cancellation = setTimeout(() => { localStorage.setItem(localStorageNamePrefix + '_IS_SHOWN', 'true'); notify(text); }, delay > 0 ? delay * 1000 : 1000); Notification.requestPermission().then((permission) => { if (permission === 'granted') { notify = (t) => new Notification(t); } }); return cancellation; } //*************************************************************************** function createElementFromTextAndAppend(wrapper, html) { const span = document.createElement('span'); span.innerHTML = html.trim(); wrapper.append(span); return wrapper; }
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址