description
当前为
// ==UserScript==
// @name Faction Last Active
// @namespace namespace
// @version 0.5
// @description description
// @author tos
// @match *.torn.com/factions.php*
// @grant GM_addStyle
// ==/UserScript==
const apiKey = 'APIKEY'
GM_addStyle(`
.last_action_icon {
cursor: pointer;
vertical-align: middle;
display: inline-block;
background-image: url(/images/v2/sidebar_icons_desktop_2017.png);
background-repeat: no-repeat;
background-position-y: -785px;
width: 34px;
height: 30px;
}
.member_active {
color: green;
}
.member_away {
color: red;
}
`)
let faction = window.location.search.split('ID=')[1] || ''
const get_api = async (fac = faction, key = apiKey) => {
const response = await fetch(`https://api.torn.com/faction/${faction}$?selections=basic&key=${key}`)
return await response.json()
}
const toggleLastAction = (iconsTitle, memberUL) => {
if (iconsTitle.innerText === 'Icons') {
iconsTitle.childNodes[0].nodeValue = 'Last Action'
get_api().then((res) => {
for (const li of memberUL.children) {
const lastActionDIV = li.querySelector('.last-action')
const memberID = lastActionDIV.getAttribute('data-member-ID')
const lastAction = res.members[memberID].last_action
li.querySelector('.member-icons #iconTray').classList.toggle('hide')
lastActionDIV.innerText = lastAction
if (lastAction.includes('minutes') && parseInt(lastAction.split(' ')[0]) < 10) lastActionDIV.classList.add('member_active')
if (lastAction.includes('days')) lastActionDIV.classList.add('member_away')
lastActionDIV.classList.toggle('hide')
}
})
}
else {
iconsTitle.childNodes[0].nodeValue = 'Icons'
for (const li of memberUL.children) {
li.querySelector('.member-icons #iconTray').classList.toggle('hide')
li.querySelector('.last-action').classList.toggle('hide')
}
}
}
const add_toggle = (node) => {
const iconsTitle = node.querySelector('.title .member-icons')
const memberUL = node.querySelector('.member-list')
iconsTitle.insertAdjacentHTML('beforeend', `<i class="last_action_icon right"></i>`)
node.querySelector('.last_action_icon').addEventListener('click', () => { toggleLastAction(iconsTitle, memberUL) })
for (const li of memberUL.children) {
const memberID = li.querySelector('.kick-yes').getAttribute('data-id')
li.querySelector('.member-icons #iconTray').insertAdjacentHTML('afterend', `<div class="last-action hide" data-member-id="${memberID}"></div>`)
}
}
const observer = new MutationObserver((mutations) => {
for (const mutation of mutations) {
for (const node of mutation.addedNodes) {
if (node.className && node.querySelector('.f-war-list')) {
add_toggle(node)
}
}
}
})
const otherFactionUL = document.querySelector('.f-war-list')
if (otherFactionUL) {
add_toggle(otherFactionUL)
}
else {
const wrapper = document.querySelector('#factions')
observer.observe(wrapper, { subtree: true, childList: true })
}