Replace specific images with base64 versions on airaTrack login page
// ==UserScript==
// @name airaRetail custom UI
// @namespace http://tampermonkey.net/
// @version 1.1
// @description Replace specific images with base64 versions on airaTrack login page
// @author Alejandrocsdev
// @match http://127.0.0.1:8082/*
// @include http://192.168.10.*:8082/*
// @icon https://www.google.com/s2/favicons?sz=64&domain=0.1
// @license MIT
// @grant none
// ==/UserScript==
;(function () {
'use strict'
const { hash, pathname } = location
const isLoginPage = () => {
return pathname === '/' && (hash === '#/' || hash.startsWith('#/?'))
}
const isZonePage = () => {
return pathname === '/' && (hash === '#/zone' || hash.startsWith('#/?'))
}
const replaceImgs = () => {
if (!isLoginPage()) return
const hairImg = document.querySelector('img[src="/images/attribute/longhair.png"]')
if (hairImg) {
hairImg.src =
''
}
const pantsImg = document.querySelector('img[src="/images/attribute/longpants.png"]')
if (pantsImg) {
pantsImg.src =
''
}
}
const replacCounts = () => {
if (!isZonePage()) return
const updateStatCount = className => {
const statDiv = document.querySelector(`.${className}`)
if (!statDiv) return
const valueContainer = statDiv?.children[1]
const originalSpan = valueContainer?.firstElementChild?.firstElementChild
if (!originalSpan || originalSpan.tagName !== 'SPAN') return
// Hide original
originalSpan.style.display = 'none'
// Avoid inserting multiple times
const existing = valueContainer.querySelector('.custom-zero-span')
if (existing) return
// Create new span
const fakeSpan = document.createElement('span')
fakeSpan.textContent = '0'
fakeSpan.className = 'custom-zero-span'
// Apply your desired CSS
fakeSpan.style.lineHeight = '1'
fakeSpan.style.fontWeight = '600'
fakeSpan.style.color = 'rgb(127 185 122 / var(--un-text-opacity))'
fakeSpan.style.fontSize = '4rem'
// Insert before 'ppl' span
const pplSpan = originalSpan.parentElement.querySelector('span:nth-child(2)')
originalSpan.parentElement.insertBefore(fakeSpan, pplSpan)
}
updateStatCount('stat-1') // Incoming Traffic
updateStatCount('stat-2') // Zone Traffic
}
const observer = new MutationObserver(() => {
replaceImgs()
replacCounts()
})
observer.observe(document.body, {
childList: true,
subtree: true
})
})()