- // ==UserScript==
- // @name Survev UI Mod v5
- // @namespace http://tampermonkey.net/
- // @version 2024-08-31
- // @description QoL features for Survev.io (works with expandedwater, untested)
- // @author Blubbled
- // @match https://survev.io/*
- // @match https://expandedwater.online/
- // @icon 
- // @grant none
- // @license MIT
- // ==/UserScript==
-
-
-
- (function() {
-
- var lastCalledTime;
- var fps;
- var frameTimes = [];
- var maxFrames = 100;
- var uncappedFPS = false;
- var uiElementsEnabled = true;
- var fpsCounterEnabled = true;
- var currentCountdown = null;
- var healthBarSettingsCreated = false;
- var switchDelayEnabled = localStorage.getItem('switchDelayEnabled') === 'true';
- var customColor = localStorage.getItem('customColor') || '#ffffff';
- var colorToggleState = localStorage.getItem('colorToggle') === 'true';
-
- function requestAnimFrame() {
- if (!lastCalledTime) {
- lastCalledTime = Date.now();
- fps = 0;
- return;
- }
-
- var currentTime = Date.now();
- var delta = (currentTime - lastCalledTime) / 1000;
- lastCalledTime = currentTime;
-
- frameTimes.push(delta);
-
- if (frameTimes.length > maxFrames) {
- frameTimes.shift();
- }
-
- var totalTime = frameTimes.reduce((sum, time) => sum + time, 0);
- fps = (frameTimes.length / totalTime).toFixed(0);
- }
-
- function createFPSCounter() {
- var fpsCounter = document.createElement('div');
- fpsCounter.id = 'fps-counter';
- fpsCounter.style.position = 'fixed';
- fpsCounter.style.left = '10px';
- fpsCounter.style.top = '130px';
- fpsCounter.style.color = customColor;
- fpsCounter.style.fontSize = '20px';
- fpsCounter.style.fontWeight = 'bold';
- fpsCounter.style.zIndex = '1000';
- fpsCounter.style.backgroundColor = 'rgba(0, 0, 0, 0)';
- fpsCounter.style.padding = '5px';
- fpsCounter.style.borderRadius = '5px';
- document.body.appendChild(fpsCounter);
-
- var lastUpdate = Date.now();
-
- function updateFPSCounter() {
- requestAnimFrame();
- var now = Date.now();
- if (now - lastUpdate >= 1000) {
- fpsCounter.textContent = `FPS: ${fps}`;
- lastUpdate = now;
- }
-
- requestAnimationFrame(updateFPSCounter);
- }
-
- updateFPSCounter();
- }
-
- createFPSCounter();
-
- function toggleFPSCounter(enabled) {
- var fpsCounter = document.getElementById('fps-counter');
- if (enabled) {
- fpsCounter.style.display = 'block';
- } else {
- fpsCounter.style.display = 'none';
- }
- }
-
- function resetTextColors() {
- var fpsCounter = document.getElementById('fps-counter');
- var ammoCount = document.getElementById('ui-current-clip');
- var healCounts = document.querySelectorAll('.ui-loot-count');
-
- if (fpsCounter) fpsCounter.style.color = '';
- if (ammoCount) ammoCount.style.color = '';
- healCounts.forEach(function(healCount) {
- healCount.style.color = '';
- });
- }
-
- function updateTextColor(newColor) {
- if (!colorToggleState) {
- resetTextColors();
- return;
- }
-
- customColor = newColor;
- localStorage.setItem('customColor', newColor);
-
- var fpsCounter = document.getElementById('fps-counter');
- var ammoCount = document.getElementById('ui-current-clip');
- var healCounts = document.querySelectorAll('.ui-loot-count');
-
- if (fpsCounter) fpsCounter.style.color = newColor;
- if (ammoCount) ammoCount.style.color = newColor;
- healCounts.forEach(function(healCount) {
- healCount.style.color = newColor;
- });
- }
-
- function applyInitialTextColor() {
- if (!colorToggleState) {
- return;
- }
-
- var ammoCount = document.getElementById('ui-current-clip');
- var healCounts = document.querySelectorAll('.ui-loot-count');
-
- if (ammoCount) ammoCount.style.color = customColor;
- healCounts.forEach(function(healCount) {
- healCount.style.color = customColor;
- });
- }
-
- function applyColorOnGameUI() {
- var observer = new MutationObserver(function(mutations) {
- mutations.forEach(function(mutation) {
- if (mutation.addedNodes.length) {
- applyInitialTextColor();
- }
- });
- });
-
- observer.observe(document.body, { childList: true, subtree: true });
- }
-
- var uiTopLeft = document.getElementById('ui-top-left');
- if (uiTopLeft) {
- uiTopLeft.style.position = 'relative';
- uiTopLeft.style.left = '100px';
- }
-
- document.addEventListener("DOMContentLoaded", function() {
- if (colorToggleState) {
- applyInitialTextColor();
- }
-
- applyColorOnGameUI();
- });
-
- function createSwitchDelayToggle(settingsTab) {
- var switchDelayLabel = document.createElement('label');
- switchDelayLabel.textContent = 'Show Switch Delay';
- settingsTab.appendChild(switchDelayLabel);
-
- var switchDelayCheckbox = document.createElement('input');
- switchDelayCheckbox.type = 'checkbox';
- switchDelayCheckbox.id = 'switch-delay-checkbox';
- switchDelayCheckbox.checked = switchDelayEnabled;
- settingsTab.appendChild(switchDelayCheckbox);
- settingsTab.appendChild(document.createElement('br'));
-
- switchDelayCheckbox.addEventListener('change', function() {
- switchDelayEnabled = switchDelayCheckbox.checked;
- localStorage.setItem('switchDelayEnabled', switchDelayEnabled);
- });
- }
-
- var settingsButton = document.createElement('button');
- settingsButton.id = 'settings-button';
- settingsButton.textContent = 'Mod Settings';
- settingsButton.style.position = 'fixed';
- settingsButton.style.left = '10px';
- settingsButton.style.top = '50%';
- settingsButton.style.transform = 'translateY(-50%)';
- settingsButton.style.padding = '10px';
- settingsButton.style.fontSize = '18px';
- settingsButton.style.backgroundColor = 'rgba(0, 0, 0, 0.8)';
- settingsButton.style.color = 'white';
- settingsButton.style.zIndex = '1000';
- settingsButton.style.display = 'none';
- document.body.appendChild(settingsButton);
-
- var settingsTab = document.createElement('div');
- settingsTab.id = 'settings-tab';
- settingsTab.style.position = 'fixed';
- settingsTab.style.left = '200px';
- settingsTab.style.top = '50%';
- settingsTab.style.width = '300px';
- settingsTab.style.height = '400px';
- settingsTab.style.backgroundColor = 'rgba(0, 0, 0, 0.8)';
- settingsTab.style.color = 'white';
- settingsTab.style.padding = '20px';
- settingsTab.style.borderRadius = '10px';
- settingsTab.style.display = 'none';
- settingsTab.innerHTML = '<h2>Mod Settings (buggy, reenable uncapped FPS a few times if cursor info doesnt update)</h2>';
- document.body.appendChild(settingsTab);
-
- var fpsSettingWrapper = document.createElement('div');
- fpsSettingWrapper.style.textAlign = 'left';
-
- var fpsLabel = document.createElement('label');
- fpsLabel.textContent = 'Enable Uncapped FPS';
- fpsLabel.setAttribute('for', 'uncapped-fps-checkbox');
-
- var fpsCheckbox = document.createElement('input');
- fpsCheckbox.type = 'checkbox';
- fpsCheckbox.id = 'uncapped-fps-checkbox';
-
- fpsSettingWrapper.appendChild(fpsLabel);
- fpsSettingWrapper.appendChild(fpsCheckbox);
-
- settingsTab.appendChild(fpsSettingWrapper);
-
- var uiSettingWrapper = document.createElement('div');
- uiSettingWrapper.style.textAlign = 'left';
-
- var uiLabel = document.createElement('label');
- uiLabel.textContent = 'Show Cursor Info';
- uiLabel.setAttribute('for', 'ui-elements-checkbox');
-
- var uiCheckbox = document.createElement('input');
- uiCheckbox.type = 'checkbox';
- uiCheckbox.id = 'ui-elements-checkbox';
-
- uiSettingWrapper.appendChild(uiLabel);
- uiSettingWrapper.appendChild(uiCheckbox);
-
- settingsTab.appendChild(uiSettingWrapper);
-
- var fpsCounterWrapper = document.createElement('div');
- fpsCounterWrapper.style.textAlign = 'left';
-
- var fpsCounterLabel = document.createElement('label');
- fpsCounterLabel.textContent = 'Show FPS Counter';
- fpsCounterLabel.setAttribute('for', 'fps-counter-checkbox');
-
- var fpsCounterCheckbox = document.createElement('input');
- fpsCounterCheckbox.type = 'checkbox';
- fpsCounterCheckbox.id = 'fps-counter-checkbox';
-
- fpsCounterWrapper.appendChild(fpsCounterLabel);
- fpsCounterWrapper.appendChild(fpsCounterCheckbox);
-
- settingsTab.appendChild(fpsCounterWrapper);
-
- createSwitchDelayToggle(settingsTab);
- settingsTab.appendChild(document.createElement('br'));
-
- function toggleUncappedFPS(enabled) {
- if (enabled) {
- window.requestAnimationFrame = function(callback) {
- return setTimeout(callback, 1);
- };
- } else {
- window.requestAnimationFrame = function(callback) {
- return setTimeout(callback, 1000 / 60);
- };
- }
- }
-
-
-
- var colorToggleLabel = document.createElement('label');
- colorToggleLabel.textContent = 'Enable Custom Text Color';
- settingsTab.appendChild(colorToggleLabel);
-
- var colorToggleCheckbox = document.createElement('input');
- colorToggleCheckbox.type = 'checkbox';
- colorToggleCheckbox.id = 'color-toggle-checkbox';
- colorToggleCheckbox.checked = colorToggleState;
- settingsTab.appendChild(colorToggleCheckbox);
- settingsTab.appendChild(document.createElement('br'));
-
- var colorPickerLabel = document.createElement('label');
- colorPickerLabel.textContent = 'Select Text Color';
- settingsTab.appendChild(colorPickerLabel);
-
- var colorPicker = document.createElement('input');
- colorPicker.type = 'color';
- colorPicker.value = customColor;
- colorPicker.disabled = !colorToggleState;
- settingsTab.appendChild(colorPicker);
- settingsTab.appendChild(document.createElement('br'));
-
- colorToggleCheckbox.addEventListener('change', function() {
- colorToggleState = colorToggleCheckbox.checked;
- colorPicker.disabled = !colorToggleState;
- if (colorToggleState) {
- updateTextColor(colorPicker.value);
- } else {
- resetTextColors();
- }
- localStorage.setItem('colorToggle', colorToggleState);
- });
- colorPicker.addEventListener('input', function() {
- if (colorToggleState) {
- updateTextColor(colorPicker.value);
- }
- });
-
- function updateSettingsButtonVisibility() {
- var loadingOverlay = document.querySelector('.play-loading-outer');
-
- if (loadingOverlay && window.getComputedStyle(loadingOverlay).opacity === '0') {
- settingsButton.style.display = 'block';
- } else {
- settingsButton.style.display = 'none';
- settingsTab.style.display = 'none';
- }
-
- if (!healthBarSettingsCreated) {
- createHealthBarSettingsUI(settingsTab);
- healthBarSettingsCreated = true;
- }
-
- if (healthBarColorToggleState) {
- observeHealthBar();
- }
- }
-
- setInterval(updateSettingsButtonVisibility, 100);
-
- settingsButton.addEventListener('click', function() {
- if (settingsTab.style.display === 'none') {
- settingsTab.style.display = 'block';
- } else {
- settingsTab.style.display = 'none';
- }
- });
-
- function loadSettings() {
- var uncappedFPSSetting = localStorage.getItem('uncappedFPS') === 'true';
- var uiElementsSetting = localStorage.getItem('uiElementsEnabled') === 'true';
- var fpsCounterSetting = localStorage.getItem('fpsCounterEnabled') === 'true';
-
- fpsCheckbox.checked = uncappedFPSSetting;
- uiCheckbox.checked = uiElementsSetting;
- fpsCounterCheckbox.checked = fpsCounterSetting;
-
- toggleUncappedFPS(uncappedFPSSetting);
- toggleUIElementDisplay(uiElementsSetting);
- toggleFPSCounter(fpsCounterSetting);
-
- if (colorToggleState) {
- updateTextColor(customColor);
- }
- }
-
- function saveSettings() {
- var uncappedFPSSetting = fpsCheckbox.checked;
- var uiElementsSetting = uiCheckbox.checked;
- var fpsCounterSetting = fpsCounterCheckbox.checked;
-
- localStorage.setItem('uncappedFPS', uncappedFPSSetting);
- localStorage.setItem('uiElementsEnabled', uiElementsSetting);
- localStorage.setItem('fpsCounterEnabled', fpsCounterSetting);
-
- toggleUncappedFPS(uncappedFPSSetting);
- toggleUIElementDisplay(uiElementsSetting);
- toggleFPSCounter(fpsCounterSetting);
- }
-
- loadSettings();
-
- fpsCheckbox.addEventListener('change', saveSettings);
- uiCheckbox.addEventListener('change', saveSettings);
- fpsCounterCheckbox.addEventListener('change', saveSettings);
-
- var healthBarColor = localStorage.getItem('healthBarColor') || '#00ff00';
- var healthBarDegradationColor = localStorage.getItem('healthBarDegradationColor') || '#ff0000';
- var healthBarColorToggleState = localStorage.getItem('healthBarColorToggle') === 'true';
-
- function interpolateColor(color1, color2, factor) {
- var result = color1.slice(1).match(/.{2}/g).map((hex, i) => {
- return Math.round(parseInt(hex, 16) * (1 - factor) + parseInt(color2.slice(1).match(/.{2}/g)[i], 16) * factor).toString(16).padStart(2, '0');
- });
- return `#${result.join('')}`;
- }
-
-
- function updateHealthBarColor(percentage) {
- if (!healthBarColorToggleState) return;
- var interpolatedColor = interpolateColor(healthBarColor, healthBarDegradationColor, 1 - percentage);
- var healthBar = document.getElementById('ui-health-actual');
- if (healthBar) {
- healthBar.style.backgroundColor = interpolatedColor;
- }
- }
-
- function observeHealthBar() {
- var healthBar = document.getElementById('ui-health-actual');
- if (!healthBar) return;
-
- var observer = new MutationObserver(function() {
- var width = parseFloat(healthBar.style.width);
- var percentage = width / 100;
- updateHealthBarColor(percentage);
- });
-
- observer.observe(healthBar, { attributes: true, attributeFilter: ['style'] });
- }
-
-
- function createHealthBarSettingsUI(settingsTab) {
-
- var healthBarColorToggleLabel = document.createElement('label');
- settingsTab.appendChild(document.createElement('br'));
- healthBarColorToggleLabel.textContent = 'Enable Custom Health Bar Color';
- settingsTab.appendChild(healthBarColorToggleLabel);
-
- var healthBarColorToggleCheckbox = document.createElement('input');
- healthBarColorToggleCheckbox.type = 'checkbox';
- healthBarColorToggleCheckbox.id = 'health-bar-color-toggle-checkbox';
- healthBarColorToggleCheckbox.checked = healthBarColorToggleState;
- settingsTab.appendChild(healthBarColorToggleCheckbox);
- settingsTab.appendChild(document.createElement('br'));
-
-
- var healthBarColorLabel = document.createElement('label');
- healthBarColorLabel.textContent = 'Health Bar Color:';
- settingsTab.appendChild(healthBarColorLabel);
-
- var healthBarColorPicker = document.createElement('input');
- healthBarColorPicker.type = 'color';
- healthBarColorPicker.value = healthBarColor;
- healthBarColorPicker.disabled = !healthBarColorToggleState;
- settingsTab.appendChild(healthBarColorPicker);
- settingsTab.appendChild(document.createElement('br'));
-
-
- var healthBarDegradationColorLabel = document.createElement('label');
- healthBarDegradationColorLabel.textContent = 'Health Bar Degradation Color:';
- settingsTab.appendChild(healthBarDegradationColorLabel);
-
- var healthBarDegradationColorPicker = document.createElement('input');
- healthBarDegradationColorPicker.type = 'color';
- healthBarDegradationColorPicker.value = healthBarDegradationColor;
- healthBarDegradationColorPicker.disabled = !healthBarColorToggleState;
- settingsTab.appendChild(healthBarDegradationColorPicker);
- settingsTab.appendChild(document.createElement('br'));
-
-
- healthBarColorToggleCheckbox.addEventListener('change', function() {
- healthBarColorToggleState = healthBarColorToggleCheckbox.checked;
- localStorage.setItem('healthBarColorToggle', healthBarColorToggleState);
- healthBarColorPicker.disabled = !healthBarColorToggleState;
- healthBarDegradationColorPicker.disabled = !healthBarColorToggleState;
-
- if (healthBarColorToggleState) {
- observeHealthBar();
- }
- });
-
- healthBarColorPicker.addEventListener('input', function() {
- healthBarColor = healthBarColorPicker.value;
- localStorage.setItem('healthBarColor', healthBarColor);
- });
-
- healthBarDegradationColorPicker.addEventListener('input', function() {
- healthBarDegradationColor = healthBarDegradationColorPicker.value;
- localStorage.setItem('healthBarDegradationColor', healthBarDegradationColor);
- });
- }
- var gunSwitchDelayMap = {
- "AWM-S": 1000,
- "BLR 81": 1000,
- "Model 94": 1000,
- "Mosin-Nagant": 1000,
- "SV-98": 1000,
- "Scout Elite": 1000,
-
- "Hawk 12G": 900,
- "Heart Cannon": 900,
- "M1100": 900,
- "M134": 900,
- "M79": 900,
- "M870": 900,
- "Potato Cannon": 900,
-
- "AK-47": 750,
- "AN-94": 750,
- "BAR M1918": 750,
- "CZ-3A1": 750,
- "DP-28": 750,
- "FAMAS": 750,
- "Groza": 750,
- "Groza-S": 750,
- "L86A2": 750,
- "M1 Garand": 750,
- "M1014": 750,
- "M1A1": 750,
- "M249": 750,
- "M39 EMR": 750,
- "M416": 750,
- "M4A1-S": 750,
- "MAC-10": 750,
- "MP5": 750,
- "Mk 12 SPR": 750,
- "Mk45G": 750,
- "PKM": 750,
- "PKP Pecheneg": 750,
- "QBB-97": 750,
- "SCAR-H": 750,
- "SCAR-SSR": 750,
- "SPAS-12": 750,
- "SVD-63": 750,
- "Saiga-12": 750,
- "Spud Gun": 750,
- "UMP9": 750,
- "USAS-12": 750,
- "VSS": 750,
- "Vector": 750,
-
- "Bugle": 300,
- "DEagle 50": 300,
- "Dual DEagle 50": 300,
- "Dual Flare Gun": 300,
- "Dual OT-38": 300,
- "Dual OTs-38": 300,
- "Dual P30L": 300,
- "Dual Peacemaker": 300,
- "Flare Gun": 300,
- "MP220": 300,
- "OT-38": 300,
- "OTs-38": 300,
- "Peacemaker": 300,
- "Rainbow Blaster": 300,
-
- "Dual G18C": 250,
- "Dual M1911": 250,
- "Dual M9": 250,
- "Dual M93R": 250,
- "G18C": 250,
- "M1911": 250,
- "M9": 250,
- "M9 Cursed": 250,
- "M93R": 250,
- "P30L": 250
- };
-
-
- var currentCountdown = null;
-
- function createSwitchDelayText() {
- var delayText = document.createElement('div');
- delayText.id = 'switch-delay-text';
- delayText.style.position = 'fixed';
- delayText.style.color = 'red';
- delayText.style.fontSize = '25px';
- delayText.style.fontWeight = 'bold';
- delayText.style.zIndex = '1000';
- delayText.style.left = '50%';
- delayText.style.transform = 'translateX(-50%)';
- delayText.style.top = '40%';
- document.body.appendChild(delayText);
- return delayText;
- }
-
-
- function showSwitchDelay(gunName, delayMs) {
- if (!switchDelayEnabled) return;
-
- if (currentCountdown) {
- clearInterval(currentCountdown);
- }
-
- if (!gunSwitchDelayMap[gunName]) {
- return;
- }
-
- var delayInSeconds = (delayMs / 1000).toFixed(2);
- var delayText = document.getElementById('switch-delay-text') || createSwitchDelayText();
-
- delayText.textContent = `${delayInSeconds}s`;
- delayText.style.display = 'block';
-
- currentCountdown = setInterval(function() {
- delayInSeconds -= 0.01;
- delayText.textContent = `${delayInSeconds.toFixed(2)}s`;
-
- if (delayInSeconds <= 0) {
- clearInterval(currentCountdown);
- delayText.style.display = 'none';
- currentCountdown = null;
- }
- }, 10);
- }
-
-
- function detectWeaponSwitch() {
- var previousWeapon = null;
-
- setInterval(function() {
- var equippedWeapon = document.querySelector('.ui-weapon-switch[style*="background-color: rgba(0, 0, 0, 0.4)"], .ui-weapon-switch[style*="opacity: 1"]');
- if (equippedWeapon) {
- var weaponName = equippedWeapon.querySelector('.ui-weapon-name').textContent.trim();
- if (weaponName !== previousWeapon) {
- previousWeapon = weaponName;
-
- var delayMs = gunSwitchDelayMap[weaponName];
- if (delayMs) {
- showSwitchDelay(weaponName, delayMs);
- }
- }
- }
- }, 100);
- }
-
- detectWeaponSwitch();
-
-
- function periodicallyShowKillCounter() {
- showKillCounter();
- setTimeout(periodicallyShowKillCounter, 100);
- }
-
- function showKillCounter() {
- var killCounter = document.getElementById('ui-kill-counter-wrapper');
- if (killCounter) {
- killCounter.style.display = 'block';
- killCounter.style.position = 'fixed';
- killCounter.style.left = '5px';
- killCounter.style.top = '-25px';
- killCounter.style.color = 'white';
- killCounter.style.fontSize = '20px';
- killCounter.style.fontWeight = 'bold';
- killCounter.style.zIndex = '1000';
- killCounter.style.backgroundColor = 'rgba(0, 0, 0, 0)';
- killCounter.style.padding = '5px';
- killCounter.style.borderRadius = '5px';
-
- var counterText = killCounter.querySelector('.counter-text');
- if (counterText) {
- counterText.style.minWidth = '30px';
- }
- }
- }
-
- function calculateAverageBoostWidth() {
- var counterLengths = [98.5, 98.5, 147.75, 49.25];
- var boostCounters = document.querySelectorAll('#ui-boost-counter .ui-bar-inner');
- var totalWidth = 0;
-
- boostCounters.forEach(function(counter, index) {
- var widthPercentage = parseFloat(counter.style.width);
- var unitLength = counterLengths[index];
- totalWidth += (widthPercentage / 100) * unitLength;
- });
-
- var totalUnitLength = counterLengths.reduce((a, b) => a + b, 0);
- var averageWidthPercentage = (totalWidth / totalUnitLength) * 100;
-
- return averageWidthPercentage.toFixed(2) + "%";
- }
-
- function toggleUIElementDisplay(enabled) {
- if (enabled) {
-
- var healthBarWidthCopy = document.createElement('span');
- healthBarWidthCopy.id = 'health-bar-width-copy';
- healthBarWidthCopy.classList.add('unselectable');
- healthBarWidthCopy.style.position = 'fixed';
- healthBarWidthCopy.style.fontSize = '25px';
- healthBarWidthCopy.style.fontWeight = 'bold';
- healthBarWidthCopy.style.display = 'none';
-
- var ammoCountCopy = document.createElement('span');
- ammoCountCopy.id = 'ammo-count-copy';
- ammoCountCopy.classList.add('unselectable');
- ammoCountCopy.style.position = 'fixed';
- ammoCountCopy.style.fontSize = '25px';
- ammoCountCopy.style.fontWeight = 'bold';
- ammoCountCopy.style.display = 'none';
-
- var weaponNameCopy = document.createElement('span');
- weaponNameCopy.id = 'weapon-name-copy';
- weaponNameCopy.classList.add('unselectable');
- weaponNameCopy.style.position = 'fixed';
- weaponNameCopy.style.fontSize = '20px';
- weaponNameCopy.style.fontWeight = 'bold';
- weaponNameCopy.style.display = 'none';
-
- var boostWidthCopy = document.createElement('span');
- boostWidthCopy.id = 'boost-width-copy';
- boostWidthCopy.classList.add('unselectable');
- boostWidthCopy.style.position = 'fixed';
- boostWidthCopy.style.fontSize = '20px';
- boostWidthCopy.style.fontWeight = 'bold';
- boostWidthCopy.style.color = 'orange';
- boostWidthCopy.style.display = 'none';
-
- function updateHealthBarWidthCopy() {
- var healthBar = document.getElementById('ui-health-actual');
- if (healthBar && healthBar.offsetWidth > 0 && healthBar.offsetHeight > 0) {
- var healthBarWidth = Math.round(parseFloat(healthBar.style.width));
- var healthBarColor = healthBar.style.backgroundColor;
-
- healthBarWidthCopy.textContent = healthBarWidth + "%";
- healthBarWidthCopy.style.color = healthBarColor;
- healthBarWidthCopy.style.display = 'block';
- } else {
- healthBarWidthCopy.style.display = 'none';
- }
- }
-
- function updateAmmoCountCopy() {
- var ammoCountElement = document.getElementById('ui-current-clip');
-
- if (ammoCountElement && window.getComputedStyle(ammoCountElement).display !== 'none' && parseFloat(window.getComputedStyle(ammoCountElement).opacity) > 0) {
- var ammoCount = ammoCountElement.textContent;
- ammoCountCopy.textContent = ammoCount;
- ammoCountCopy.style.color = ammoCountElement.style.color;
- ammoCountCopy.style.display = 'block';
- } else {
- ammoCountCopy.style.display = 'none';
- }
- }
-
- function updateWeaponNameCopy() {
- var equippedWeapon = document.querySelector('.ui-weapon-switch[style*="background-color: rgba(0, 0, 0, 0.4)"], .ui-weapon-switch[style*="opacity: 1"]');
- if (equippedWeapon) {
- var weaponName = equippedWeapon.querySelector('.ui-weapon-name').textContent;
- weaponNameCopy.textContent = weaponName;
- weaponNameCopy.style.color = 'white';
- weaponNameCopy.style.display = 'block';
- } else {
- weaponNameCopy.style.display = 'none';
- }
- }
-
- function updateBoostWidthCopy() {
- var boostElement = document.getElementById('ui-boost-counter');
- if (boostElement && window.getComputedStyle(boostElement).display !== 'none' && parseFloat(window.getComputedStyle(boostElement).opacity) > 0) {
- var averageBoostWidth = calculateAverageBoostWidth();
- boostWidthCopy.textContent = averageBoostWidth;
- boostWidthCopy.style.display = 'block';
- } else {
- boostWidthCopy.style.display = 'none';
- }
- }
-
- function followCursor(event) {
- healthBarWidthCopy.style.left = `${event.clientX - 70}px`;
- healthBarWidthCopy.style.top = `${event.clientY + 25}px`;
-
- ammoCountCopy.style.left = `${event.clientX + 40}px`;
- ammoCountCopy.style.top = `${event.clientY + 25}px`;
-
- weaponNameCopy.style.left = `${event.clientX + 40}px`;
- weaponNameCopy.style.top = `${event.clientY + 50}px`;
-
- boostWidthCopy.style.left = `${event.clientX - 70}px`;
- boostWidthCopy.style.top = `${event.clientY + 50}px`;
- }
- document.addEventListener('mousemove', followCursor);
-
- healthBarWidthCopy.style.webkitTouchCallout = 'none'; /* iOS Safari */
- healthBarWidthCopy.style.webkitUserSelect = 'none'; /* Safari */
- healthBarWidthCopy.style.userSelect = 'none'; /* Standard syntax */
-
- ammoCountCopy.style.webkitTouchCallout = 'none'; /* iOS Safari */
- ammoCountCopy.style.webkitUserSelect = 'none'; /* Safari */
- ammoCountCopy.style.userSelect = 'none'; /* Standard syntax */
-
- weaponNameCopy.style.webkitTouchCallout = 'none'; /* iOS Safari */
- weaponNameCopy.style.webkitUserSelect = 'none'; /* Safari */
- weaponNameCopy.style.userSelect = 'none'; /* Standard syntax */
-
- boostWidthCopy.style.webkitTouchCallout = 'none'; /* iOS Safari */
- boostWidthCopy.style.webkitUserSelect = 'none'; /* Safari */
- boostWidthCopy.style.userSelect = 'none'; /* Standard syntax */
-
- document.body.appendChild(healthBarWidthCopy);
- document.body.appendChild(ammoCountCopy);
- document.body.appendChild(weaponNameCopy);
- document.body.appendChild(boostWidthCopy);
-
- updateHealthBarWidthCopy();
- updateAmmoCountCopy();
- updateWeaponNameCopy();
- updateBoostWidthCopy();
-
- var healthObserver = new MutationObserver(updateHealthBarWidthCopy);
- var healthTargetNode = document.getElementById('ui-health-actual');
- if (healthTargetNode) {
- healthObserver.observe(healthTargetNode, { attributes: true, attributeFilter: ['style', 'class'] });
- }
- if (healthTargetNode && healthTargetNode.parentElement) {
- healthObserver.observe(healthTargetNode.parentElement, { attributes: true, attributeFilter: ['style', 'class'] });
- }
-
- var ammoObserver = new MutationObserver(updateAmmoCountCopy);
- var ammoTargetNode = document.getElementById('ui-current-clip');
- if (ammoTargetNode) {
- ammoObserver.observe(ammoTargetNode, { attributes: true, childList: true, subtree: true });
- }
-
- var weaponObserver = new MutationObserver(updateWeaponNameCopy);
- var weaponTargetNodes = document.querySelectorAll('.ui-weapon-switch');
- weaponTargetNodes.forEach(function(node) {
- weaponObserver.observe(node, { attributes: true, attributeFilter: ['style', 'class'] });
- });
-
- var boostObserver = new MutationObserver(updateBoostWidthCopy);
- var boostTargetNodes = document.querySelectorAll('#ui-boost-counter .ui-bar-inner');
- boostTargetNodes.forEach(function(node) {
- boostObserver.observe(node, { attributes: true, attributeFilter: ['style', 'class'] });
- });
-
- } else {
- var healthBarWidthCopy = document.getElementById('health-bar-width-copy');
- if (healthBarWidthCopy) {
- healthBarWidthCopy.parentNode.removeChild(healthBarWidthCopy);
- }
-
- var ammoCountCopy = document.getElementById('ammo-count-copy');
- if (ammoCountCopy) {
- ammoCountCopy.parentNode.removeChild(ammoCountCopy);
- }
-
- var weaponNameCopy = document.getElementById('weapon-name-copy');
- if (weaponNameCopy) {
- weaponNameCopy.parentNode.removeChild(weaponNameCopy);
- }
-
- var boostWidthCopy = document.getElementById('boost-width-copy');
- if (boostWidthCopy) {
- boostWidthCopy.parentNode.removeChild(boostWidthCopy);
- }
- }
- }
-
- toggleUIElementDisplay(true);
- showKillCounter();
- periodicallyShowKillCounter();
- })();