// ==UserScript==
// @name [Pokeclicker] Additional Visual Settings
// @namespace Pokeclicker Scripts
// @match https://www.pokeclicker.com/
// @grant none
// @version 1.9
// @author Ephenia
// @description Adds additional settings for hiding some visual things to help out with performance.
// ==/UserScript==
var checkWildPokeName;
var checkWildPokeDefeat;
var checkWildPokeImg;
var checkWildPokeHealth;
var checkWildPokeCatch;
var checkAllNotification;
var notificFunc = Notifier.notify;
var newSave;
var trainerCards;
function initVisualSettings() {
var getMenu = document.getElementById('startMenu');
var quickSettings = document.createElement("img");
quickSettings.id = "quick-settings"
quickSettings.src = ""
quickSettings.setAttribute("href", "#settingsModal")
quickSettings.setAttribute("data-toggle", "modal")
getMenu.prepend(quickSettings)
var quickPokedex = document.createElement("img");
quickPokedex.id = "quick-pokedex"
quickPokedex.src = ""
quickPokedex.setAttribute("href", "#pokedexModal")
quickPokedex.setAttribute("data-toggle", "modal")
getMenu.prepend(quickPokedex)
document.querySelectorAll('tr[data-bind*="currencyMainDisplayReduced"')[0].outerHTML += `<tr>
<td class="p-2">
<label class="m-0">Show wild Pokémon Name</label>
</td>
<td class="p-2">
<input id="poke-name" type="checkbox">
</td>
</tr>
<tr>
<td class="p-2">
<label class="m-0">Show wild Pokémon Defeated</label>
</td>
<td class="p-2">
<input id="poke-defeat" type="checkbox">
</td>
</tr>
<tr>
<td class="p-2">
<label class="m-0">Show wild Pokémon Image</label>
</td>
<td class="p-2">
<input id="poke-image" type="checkbox">
</td>
</tr>
<tr>
<td class="p-2">
<label class="m-0">Show Pokémon Health</label>
</td>
<td class="p-2">
<input id="poke-health" type="checkbox">
</td>
</tr>
<tr>
<td class="p-2">
<label class="m-0">Show Catch Icon</label>
</td>
<td class="p-2">
<input id="poke-catch" type="checkbox">
</td>
</tr>`
var notifiyHTML = document.createElement("tr");
notifiyHTML.innerHTML = `<td class="p-2">
<label class="m-0">Disable all Notifications</label>
</td>
<td class="p-2 tight">
<input id="all-notify" type="checkbox">
</td>`
//Moved to async function because it fails to execute on loading screen so we keep trying until the element exists
//Settings screen changed, this is where the option should go now
document.querySelector('[id="settingsNotificationGeneral"] table tbody').prepend(notifiyHTML)
//Add 'Disable all notifications' option
document.querySelector('#all-notify').addEventListener('change', event => {
if (event.target.checked == false) {
checkAllNotification = "OFF";
localStorage.setItem("checkAllNotification", "OFF");
Notifier.notify = notificFunc;
} else {
checkAllNotification = "ON";
localStorage.setItem("checkAllNotification", "ON");
remNotifications();
}
});
checkWildPokeName = localStorage.getItem('checkWildPokeName');
checkWildPokeDefeat = localStorage.getItem('checkWildPokeDefeat');
checkWildPokeImg = localStorage.getItem('checkWildPokeImg');
checkWildPokeHealth = localStorage.getItem('checkWildPokeHealth');
checkWildPokeCatch = localStorage.getItem('checkWildPokeCatch');
checkAllNotification = localStorage.getItem('checkAllNotification');
addGlobalStyle('.pageItemTitle { height:38px }');
addGlobalStyle('#quick-settings { height:36px;background-color:#eee;border:4px solid #eee;cursor:pointer; }');
addGlobalStyle('#quick-settings:hover { background-color:#ddd;border: 4px solid #ddd; }');
addGlobalStyle('#quick-pokedex { height:36px;background-color:#eee;border:4px solid #eee;cursor:pointer; }');
addGlobalStyle('#quick-pokedex:hover { background-color:#ddd;border: 4px solid #ddd; }');
addGlobalStyle('#shortcutsContainer { display: block !important; }');
addGlobalStyle('.gyms-leaders { display: flex;pointer-events: none;position: absolute;height: 36px;top: 0;left: 0;image-rendering: pixelated; }');
addGlobalStyle('.gyms-badges { position: absolute;height: 36px;display: flex;top: 0;right: 0; }');
//The elements removed by the scripts don't ever get added back after a restart, waiting a second before removing makes them load properly
if (checkWildPokeName == "OFF") {
document.querySelector('#poke-name').checked = true
} else {
remPokeName();
}
if (checkWildPokeDefeat == "OFF") {
document.querySelector('#poke-defeat').checked = true
} else {
remPokeDefeat();
}
if (checkWildPokeImg == "OFF") {
document.querySelector('#poke-image').checked = true
} else {
remPokeImg();
}
if (checkWildPokeHealth == "OFF") {
document.querySelector('#poke-health').checked = true
} else {
remPokeHealth();
}
if (checkWildPokeCatch == "OFF") {
document.querySelector('#poke-catch').checked = true
} else {
remPokeCatch();
}
if (checkAllNotification == "ON") {
document.querySelector('#all-notify').checked = true
remNotifications();
}
document.getElementById('map').addEventListener('click', event => {
if (event.target.matches('[data-route]')) {
if (checkWildPokeName == "ON") {
remPokeName();
}
if (checkWildPokeDefeat == "ON") {
remPokeDefeat();
}
if (checkWildPokeImg == "ON") {
remPokeImg();
}
if (checkWildPokeHealth == "ON") {
remPokeHealth();
}
if (checkWildPokeCatch == "ON") {
remPokeCatch();
}
}
});
document.querySelector('#poke-name').addEventListener('change', event => {
if (event.target.checked == true) {
checkWildPokeName = "OFF";
localStorage.setItem("checkWildPokeName", "OFF");
} else {
checkWildPokeName = "ON";
localStorage.setItem("checkWildPokeName", "ON");
}
});
document.querySelector('#poke-defeat').addEventListener('change', event => {
if (event.target.checked == true) {
checkWildPokeDefeat = "OFF";
localStorage.setItem("checkWildPokeDefeat", "OFF");
} else {
checkWildPokeDefeat = "ON";
localStorage.setItem("checkWildPokeDefeat", "ON");
}
});
document.querySelector('#poke-image').addEventListener('change', event => {
if (event.target.checked == true) {
checkWildPokeImg = "OFF";
localStorage.setItem("checkWildPokeImg", "OFF");
} else {
checkWildPokeImg = "ON";
localStorage.setItem("checkWildPokeImg", "ON");
}
});
document.querySelector('#poke-health').addEventListener('change', event => {
if (event.target.checked == true) {
checkWildPokeHealth = "OFF";
localStorage.setItem("checkWildPokeHealth", "OFF");
} else {
checkWildPokeHealth = "ON";
localStorage.setItem("checkWildPokeHealth", "ON");
}
});
document.querySelector('#poke-catch').addEventListener('change', event => {
if (event.target.checked == true) {
checkWildPokeCatch = "OFF";
localStorage.setItem("checkWildPokeCatch", "OFF");
} else {
checkWildPokeCatch = "ON";
localStorage.setItem("checkWildPokeCatch", "ON");
}
});
function remPokeName() {
var enemyName = document.querySelectorAll('knockout[data-bind*="text: Battle.enemyPokemon().name"]');
if (enemyName.length > 0) {
enemyName[0].remove()
}
var caughtStatus = document.querySelectorAll('knockout[data-bind*="caughtStatusTemplate"');
if (caughtStatus.length > 0) {
caughtStatus[0].remove()
}
}
function remPokeDefeat() {
var pokeDefeat = document.querySelectorAll('knockout[data-bind*="App.game.statistics.routeKills"]');
if (pokeDefeat.length > 0) {
pokeDefeat[0].remove()
}
}
function remPokeImg() {
var enemyPoke = document.querySelectorAll('img.enemy');
if (enemyPoke.length > 0) {
enemyPoke[0].remove()
}
}
function remPokeHealth() {
var healthBar = document.querySelectorAll('.progress.hitpoints');
if (healthBar.length > 0) {
healthBar[0].remove()
}
}
function remPokeCatch() {
var catchIcon = document.querySelectorAll('.catchChance');
if (catchIcon.length > 0) {
catchIcon[0].remove()
}
}
function remNotifications() {
Notifier.notify = function(message) {
const sound = message.sound;
if (typeof sound != 'undefined') {
sound.play();
}
}
}
//Add dock button
var dockButton = document.createElement('button')
dockButton.style = 'position: absolute; left: 32px; top: 0px; width: auto; height: 41px; font-size: 11px;'
dockButton.className = 'btn btn-block btn-success'
dockButton.id = 'dock-button'
dockButton.textContent = 'Dock'
document.getElementById('townMap').appendChild(dockButton)
document.getElementById('dock-button').addEventListener('click', MapHelper.openShipModal, false)
//Add Gyms button
const gymsButton = document.createElement('button');
gymsButton.style = 'position: absolute;left: 75px;top: -8px;width: auto;height: 41px;font-size: 11px;';
gymsButton.className = 'btn btn-block btn-success';
gymsButton.id = 'gyms-button';
gymsButton.textContent = 'Gyms';
document.getElementById('townMap').appendChild(gymsButton);
document.getElementById('gyms-button').addEventListener('click', () => { generateGymsList();$('#GymsModal').modal('show'); }, false);
createGymModal();
function createGymModal() {
const gymModal = document.createElement('div');
gymModal.setAttribute('id', 'GymsModal');
gymModal.setAttribute('class', 'modal noselect fade');
gymModal.setAttribute('tabindex', '-1');
gymModal.setAttribute('role', 'dialogue');
gymModal.setAttribute('aria-labelledby', 'GymsModalLabel');
gymModal.innerHTML = `<div class="modal-dialog modal-dialog-scrollable modal-dialog-centered modal-sm" role="document">
<div class="modal-content">
<div class="modal-header" style="justify-content: space-around;">
<h5 id="gyms-title" class="modal-title"></h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">×</span>
</button>
</div>
<div class="modal-body bg-ocean">
<div id="gyms-buttons"></div>
</div>
</div>
</div>`
document.getElementById('ShipModal').after(gymModal);
}
function generateGymsList() {
const gymBtns = document.getElementById('gyms-buttons');
const gymsHead = document.getElementById('gyms-title');
gymsHead.textContent = `Gym Select (${GameConstants.camelCaseToString(GameConstants.Region[player.region])})`
gymBtns.innerHTML = '';
const fragment = new DocumentFragment();
for (const gym in GymList) {
let region;
try { region = GymList[gym].parent.region } catch (err) { region = null };
if (player.region == region) {
const selGym = GymList[gym];
const btn = document.createElement('button');
btn.setAttribute('style', 'position: relative;');
btn.setAttribute('class', 'btn btn-block btn-success');
btn.addEventListener('click', () => { $("#GymsModal").modal("hide");GymRunner.startGym(selGym, false); })
selGym.isUnlocked() && MapHelper.calculateTownCssClass(selGym.parent.name) != 'locked' ? btn.disabled = false : btn.disabled = true;
btn.innerHTML = `<div class="gyms-leaders">
<img src="assets/images/gymLeaders/${selGym.leaderName}.png" onerror="this.onerror=null;this.style.display='none';">
</div>
<div class="gyms-badges">
<img src="assets/images/badges/${BadgeEnums[selGym.badgeReward]}.png" onerror="this.onerror=null;this.style.display='none';">
</div>
${selGym.leaderName}`;
fragment.appendChild(btn);
}
}
gymBtns.appendChild(fragment);
}
}
if (localStorage.getItem('checkWildPokeName') == null) {
localStorage.setItem("checkWildPokeName", "OFF");
}
if (localStorage.getItem('checkWildPokeDefeat') == null) {
localStorage.setItem("checkWildPokeDefeat", "OFF");
}
if (localStorage.getItem('checkWildPokeImg') == null) {
localStorage.setItem("checkWildPokeImg", "OFF");
}
if (localStorage.getItem('checkWildPokeHealth') == null) {
localStorage.setItem("checkWildPokeHealth", "OFF");
}
if (localStorage.getItem('checkWildPokeCatch') == null) {
localStorage.setItem("checkWildPokeCatch", "OFF");
}
if (localStorage.getItem('checkAllNotification') == null) {
localStorage.setItem("checkAllNotification", "OFF");
}
function loadScript(){
var oldInit = Preload.hideSplashScreen
Preload.hideSplashScreen = function(){
var result = oldInit.apply(this, arguments)
initVisualSettings()
return result
}
}
var scriptName = 'additionalvisualsettings'
if (document.getElementById('scriptHandler') != undefined){
var scriptElement = document.createElement('div')
scriptElement.id = scriptName
document.getElementById('scriptHandler').appendChild(scriptElement)
if (localStorage.getItem(scriptName) != null){
if (localStorage.getItem(scriptName) == 'true'){
loadScript()
}
}
else{
localStorage.setItem(scriptName, 'true')
loadScript()
}
}
else{
loadScript();
}
function addGlobalStyle(css) {
var head, style;
head = document.getElementsByTagName('head')[0];
if (!head) { return; }
style = document.createElement('style');
style.type = 'text/css';
style.innerHTML = css;
head.appendChild(style);
}