Farigh / pokeclicker-automation-desktop

Desktop packaging of https://github.com/Farigh/pokeclicker-automation
4 stars 1 forks source link

code change didnt work #21

Closed roxieraven327 closed 1 year ago

roxieraven327 commented 1 year ago

so when it comes to ephenia's scripts i did as you said but it seems to break 2 of them: Additional Visual Settings: Error says: SyntaxError: Invalid or unexpected token and also Oak Items Unlimited: Error says: ReferenceError: hasInitialized is not defined at loadScript (eval at internalloadScripts (:376:17), :35:20) at eval (eval at internalloadScripts (:376:17), :47:1)

im not sure what to do to fix it some guidance would be appreciated

Farigh commented 1 year ago

Can you share the content that you copied to the script panel, so I can see what's causing the problem?

roxieraven327 commented 1 year ago

i do apologize what do you mean by the content?

Farigh commented 1 year ago

I tried to import both scripts and I only got an error with one of them : image

Here is what I imported :

Additional Visual Settings

Content (click to show what to put in the Script content) ```js // ==UserScript== // @name [Pokeclicker] Additional Visual Settings // @namespace Pokeclicker Scripts // @author Ephenia (Credit: Optimatum) // @description Adds additional settings for hiding some visual things to help out with performance. Also, includes various features that help with ease of accessibility. // @copyright https://github.com/Ephenia // @license GPL-3.0 License // @version 2.5 // @homepageURL https://github.com/Ephenia/Pokeclicker-Scripts/ // @supportURL https://github.com/Ephenia/Pokeclicker-Scripts/issues // @downloadURL https://raw.githubusercontent.com/Ephenia/Pokeclicker-Scripts/master/additionalvisualsettings.user.js // @updateURL https://raw.githubusercontent.com/Ephenia/Pokeclicker-Scripts/master/additionalvisualsettings.user.js // @match https://www.pokeclicker.com/ // @icon https://www.google.com/s2/favicons?domain=pokeclicker.com // @grant none // @run-at document-idle // ==/UserScript== var scriptName = 'additionalvisualsettings'; var wildPokeNameDisabled = ko.observable(false); var wildPokeDefeatDisabled = ko.observable(false); var wildPokeImgDisabled = ko.observable(false); var wildPokeHealthDisabled = ko.observable(false); var wildPokeCatchDisabled = ko.observable(false); var avsDisableNotifications; function initVisualSettings() { // Add shortcut menu icons const getMenu = document.getElementById('startMenu'); const shortcutsToAdd = [ ['quick-settings', '#settingsModal', ''], ['quick-inventory', '#showItemsModal', ''], ['quick-pokedex', '#pokedexModal', ''], ]; shortcutsToAdd.forEach(([id, modal, source]) => { const quickElem = document.createElement('img'); quickElem.id = id; quickElem.src = source; quickElem.setAttribute('href', modal); quickElem.setAttribute('data-toggle', 'modal'); getMenu.prepend(quickElem); }); var scriptSettings = document.getElementById('settings-scripts'); // Create scripts settings tab if it doesn't exist yet if (!scriptSettings) { // Fixes the Scripts nav item getting wrapped to the bottom by increasing the max width of the window document.getElementById('settingsModal').querySelector('div').style.maxWidth = '850px'; // Create and attach script settings tab link const settingTabs = document.querySelector('#settingsModal ul.nav-tabs'); let li = document.createElement('li'); li.classList.add('nav-item'); li.innerHTML = `Scripts`; settingTabs.appendChild(li); // Create and attach script settings tab contents const tabContent = document.querySelector('#settingsModal .tab-content'); scriptSettings = document.createElement('div'); scriptSettings.classList.add('tab-pane'); scriptSettings.setAttribute('id', 'settings-scripts'); tabContent.appendChild(scriptSettings); } // Add AVS settings options to scripts tab let table = document.createElement('table'); table.classList.add('table', 'table-striped', 'table-hover', 'm-0'); scriptSettings.prepend(table); let header = document.createElement('thead'); header.innerHTML = 'Additional Visual Settings'; table.appendChild(header); let settingsBody = document.createElement('tbody'); settingsBody.setAttribute('id', 'settings-scripts-additionalvisualsettings'); table.appendChild(settingsBody); let settingsToAdd = [['poke-name', 'Show wild Pokémon Name'], ['poke-defeat', 'Show wild Pokémon Defeated'], ['poke-image', 'Show wild Pokémon Image'], ['poke-health', 'Show Pokémon Health'], ['poke-catch', 'Show Catch Icon'], ['all-notify', 'Disable all Notifications']]; settingsToAdd.forEach(([id, desc]) => { let elem = document.createElement('tr'); elem.innerHTML = `` + ``; settingsBody.appendChild(elem); }); document.getElementById('checkbox-poke-name').checked = !wildPokeNameDisabled(); document.getElementById('checkbox-poke-defeat').checked = !wildPokeDefeatDisabled(); document.getElementById('checkbox-poke-image').checked = !wildPokeImgDisabled(); document.getElementById('checkbox-poke-health').checked = !wildPokeHealthDisabled(); document.getElementById('checkbox-poke-catch').checked = !wildPokeCatchDisabled(); document.getElementById('checkbox-all-notify').checked = avsDisableNotifications; document.getElementById('checkbox-poke-name').addEventListener('change', event => { wildPokeNameDisabled(!event.target.checked); localStorage.setItem("wildPokeNameDisabled", wildPokeNameDisabled()); }); document.getElementById('checkbox-poke-defeat').addEventListener('change', event => { wildPokeDefeatDisabled(!event.target.checked); localStorage.setItem("wildPokeDefeatDisabled", wildPokeDefeatDisabled()); }); document.getElementById('checkbox-poke-image').addEventListener('change', event => { wildPokeImgDisabled(!event.target.checked); localStorage.setItem("wildPokeImgDisabled", wildPokeImgDisabled()); }); document.getElementById('checkbox-poke-health').addEventListener('change', event => { wildPokeHealthDisabled(!event.target.checked); localStorage.setItem("wildPokeHealthDisabled", wildPokeHealthDisabled()); }); document.getElementById('checkbox-poke-catch').addEventListener('change', event => { wildPokeCatchDisabled(!event.target.checked); localStorage.setItem("wildPokeCatchDisabled", wildPokeCatchDisabled()); }); document.getElementById('checkbox-all-notify').addEventListener('change', event => { avsDisableNotifications = event.target.checked; localStorage.setItem("avsDisableNotifications", avsDisableNotifications); }); overrideNotifications(); // Create travel shortcut buttons on town map const travelShortcutsToAdd = [ ['dock-button', 'Dock', {left: 32, top: 0}, MapHelper.openShipModal], ['gyms-button', 'Gyms', {left: 75, top: -8}, () => { generateRegionGymsList(); $('#gymsShortcutModal').modal('show'); }], ['dungeons-button', 'Dungeons', {left: 121, top: -8}, () => { generateRegionDungeonssList(); $('#dungeonsShortcutModal').modal('show'); }], ]; travelShortcutsToAdd.forEach(([id, name, pos, func]) => { const button = document.createElement('button'); button.id = id; button.textContent = name; button.className = 'btn btn-block btn-success'; button.style = `position: absolute; left: ${pos.left}px; top: ${pos.top}px; width: auto; height: 41px; font-size: 11px;`; button.addEventListener('click', func); document.getElementById('townMap').appendChild(button); }); // Create gym and dungeon shortcut modals const modalNames = ['gyms', 'dungeons']; const fragment = new DocumentFragment(); for (const name of modalNames) { const customModal = document.createElement('div'); customModal.setAttribute('class', 'modal noselect fade'); customModal.setAttribute('tabindex', '-1'); customModal.setAttribute('role', 'dialogue'); customModal.setAttribute('id', `${name}ShortcutModal`); customModal.setAttribute('aria-labelledby', `${name}ShortcutModalLabel`); customModal.innerHTML = ``; fragment.appendChild(customModal); } document.getElementById('ShipModal').after(fragment); addGlobalStyle('.pageItemTitle { height:38px }'); addGlobalStyle('#quick-settings, #quick-inventory, #quick-pokedex { height: 36px; background-color: #eee; border: 4px solid #eee; cursor: pointer; image-rendering: pixelated; }'); addGlobalStyle('#quick-pokedex { padding: 2px; }') addGlobalStyle(':is(#quick-settings, #quick-inventory, #quick-pokedex):hover { background-color:#ddd; border: 4px solid #ddd; }'); addGlobalStyle('#shortcutsContainer { display: block !important; }'); addGlobalStyle('.gyms-shortcut-leaders { display: flex; pointer-events: none; position: absolute; height: 36px; top: 0; left: 0; image-rendering: pixelated; }'); addGlobalStyle('.gyms-shortcut-badges { position: absolute; height: 36px; display: flex; top: 0; right: 0; }'); addGlobalStyle('.dungeons-shortcut-costs { position: relative; margin-right: 12px; filter: none !important }'); addGlobalStyle('#dungeons-shortcut-buttons > button:hover { -webkit-animation: bounceBackground 60s linear infinite alternate; animation: bounceBackground 60s linear infinite alternate; }'); addGlobalStyle('#dungeons-shortcut-buttons > button * { z-index: 2 }'); addGlobalStyle('.dungeons-shortcut-overlay { width: 100%; height: 100%; position: absolute; background-color: rgba(0,0,0,0.45); margin-top: -6px; margin-left: -8px; z-index: 1 !important }'); addGlobalStyle('.dungeons-shortcut-info { position: relative; font-weight: bold }'); function overrideNotifications() { Notifier.oldNotifyAVS = Notifier.notify; Notifier.notify = function(...args) { if (avsDisableNotifications) { if (args.length && args[0].sound) { args[0].sound.play(); } } else { return Notifier.oldNotifyAVS(...args); } } } function generateRegionGymsList() { const gymsBtns = document.getElementById('gyms-shortcut-buttons'); const gymsHead = document.getElementById('gyms-shortcut-modal-title'); gymsHead.textContent = `Gym Select (${GameConstants.camelCaseToString(GameConstants.Region[player.region])})`; gymsBtns.innerHTML = ''; const fragment = new DocumentFragment(); const regionGyms = Object.values(GymList).filter((gym) => gym.parent?.region === player.region); for (const gym of regionGyms) { const hasBadgeImage = !BadgeEnums[gym.badgeReward].startsWith('Elite') && BadgeEnums[gym.badgeReward] != 'None'; const badgeImage = (hasBadgeImage ? `assets/images/badges/${BadgeEnums[gym.badgeReward]}.png` : ''); const btn = document.createElement('button'); btn.setAttribute('style', 'position: relative;'); btn.setAttribute('class', 'btn btn-block btn-success'); btn.addEventListener('click', () => { if (!MapHelper.isTownCurrentLocation(gym.parent.name)) { MapHelper.moveToTown(gym.parent.name); } $("#gymsShortcutModal").modal("hide"); GymRunner.startGym(gym); }); btn.disabled = !(gym.isUnlocked() && MapHelper.calculateTownCssClass(gym.parent.name)); btn.innerHTML = `
${gym.leaderName}`; fragment.appendChild(btn); } gymsBtns.appendChild(fragment); } function generateRegionDungeonssList() { const dungeonsBtns = document.getElementById('dungeons-shortcut-buttons'); const dungeonsHead = document.getElementById('dungeons-shortcut-modal-title'); dungeonsHead.textContent = `Dungeon Select (${GameConstants.camelCaseToString(GameConstants.Region[player.region])})`; dungeonsBtns.innerHTML = ''; const fragment = new DocumentFragment(); const dungeonTowns = Object.values(TownList).filter((town) => (town.region === player.region && town.constructor.name === 'DungeonTown' && town.dungeon != null)); for (const town of dungeonTowns) { const dungeon = town.dungeon; const dungeonClears = App.game.statistics.dungeonsCleared[GameConstants.getDungeonIndex(dungeon.name)](); const canAffordEntry = App.game.wallet.currencies[GameConstants.Currency.dungeonToken]() >= dungeon.tokenCost; const canAccess = town.isUnlocked() && dungeon.isUnlocked() && canAffordEntry; const btn = document.createElement('button'); btn.setAttribute('style', `position: relative; background-image: url("assets/images/towns/${dungeon.name}.png"); background-position: center;opacity: ${canAccess ? 1 : 0.70}; filter: brightness(${canAccess ? 1 : 0.70});`); btn.setAttribute('class', 'btn btn-block btn-success'); btn.addEventListener('click', () => { if (!MapHelper.isTownCurrentLocation(town.name)) { MapHelper.moveToTown(town.name); } $('#dungeonsShortcutModal').modal('hide'); DungeonRunner.initializeDungeon(dungeon); }); btn.disabled = !canAccess; btn.innerHTML = `
${dungeon.tokenCost.toLocaleString('en-US')}
${dungeon.name}
${dungeonClears.toLocaleString('en-US')} clears
`; fragment.appendChild(btn); } dungeonsBtns.appendChild(fragment); } } function addGraphicsBindings() { // Must execute before game loads and applies knockout bindings // Make variables accessible for compatibility with userscript extensions window.AVSObservables = { 'wildPokeNameDisabled': wildPokeNameDisabled, 'wildPokeDefeatDisabled': wildPokeDefeatDisabled, 'wildPokeImgDisabled': wildPokeImgDisabled, 'wildPokeHealthDisabled': wildPokeHealthDisabled, 'wildPokeCatchDisabled': wildPokeCatchDisabled, }; const routeBattleView = document.querySelector('.battle-view > div[data-bind="if: App.game.gameState === GameConstants.GameState.fighting"'); // Remove pokemon name routeBattleView.querySelector('.pageItemTitle > knockout').setAttribute('data-bind', 'ifnot: AVSObservables.wildPokeNameDisabled'); // Remove pokemon defeated count const pokeDefeat = routeBattleView.querySelector('.pageItemFooter knockout[data-bind*="App.game.statistics.routeKills"]'); pokeDefeat.before(new Comment('ko ifnot: AVSObservables.wildPokeDefeatDisabled')); pokeDefeat.after(new Comment('/ko')); // Remove pokemon images const pokeImg = routeBattleView.querySelector('knockout[data-bind*="pokemonSpriteTemplate"]'); pokeImg.before(new Comment('ko ifnot: AVSObservables.wildPokeImgDisabled')); pokeImg.after(new Comment('/ko')); // Remove pokemon healthbar const pokeHealth = routeBattleView.querySelector('div.progress.hitpoints'); pokeHealth.before(new Comment('ko ifnot: AVSObservables.wildPokeHealthDisabled')); pokeHealth.after(new Comment('/ko')); // Remove catch animation const pokeCatch = routeBattleView.querySelector('div.catchChance'); pokeCatch.before(new Comment('ko ifnot: AVSObservables.wildPokeCatchDisabled')); pokeCatch.after(new Comment('/ko')); } function addOptimizeVitamins() { // Add button to vitamin menu // (must execute before game loads and applies knockout bindings) const btn = document.createElement('button'); btn.setAttribute('class', 'btn btn-link btn-sm text-decoration-none align-text-top'); btn.setAttribute('style', 'line-height: 0.6; font-size: 1rem; float: right;'); btn.setAttribute('data-bind', `click: () => { if ($data) { $data.optimizeVitamins() } }, class: (!$data.breeding ? 'text-success' : 'text-muted')`); btn.innerHTML = '⚖'; document.querySelector('#pokemonVitaminExpandedModal tbody[data-bind*="PartyController.getvitaminSortedList"] td').appendChild(btn); // Add optimize-vitamin functions for party pokemon (adapted from wiki) PartyPokemon.prototype.calcBreedingEfficiency = function(vitaminsUsed) { // attack bonus const attackBonusPercent = (GameConstants.BREEDING_ATTACK_BONUS + vitaminsUsed[GameConstants.VitaminType.Calcium]) / 100; const proteinBoost = vitaminsUsed[GameConstants.VitaminType.Protein]; const breedingAttackBonus = (this.baseAttack * attackBonusPercent) + proteinBoost; // egg steps const div = 300; const extraCycles = (vitaminsUsed[GameConstants.VitaminType.Calcium] + vitaminsUsed[GameConstants.VitaminType.Protein]) / 2; const steps = (this.eggCycles + extraCycles) * GameConstants.EGG_CYCLE_MULTIPLIER; const adjustedSteps = (steps <= div ? steps : Math.round(((steps / div) ** (1 - vitaminsUsed[GameConstants.VitaminType.Carbos] / 70)) * div)); // efficiency return (breedingAttackBonus / adjustedSteps) * GameConstants.EGG_CYCLE_MULTIPLIER; } PartyPokemon.prototype.optimizeVitamins = function() { const totalVitamins = (player.highestRegion() + 1) * 5; const carbosUnlocked = player.highestRegion() >= GameConstants.Region.unova; const calciumUnlocked = player.highestRegion() >= GameConstants.Region.hoenn; // Add our initial starting efficiency here let optimalVitamins = [0, 0, 0]; let eff = this.calcBreedingEfficiency(optimalVitamins); // Check all max-vitamin combinations for (let carbos = carbosUnlocked * totalVitamins; carbos >= 0; carbos--) { for (let calcium = calciumUnlocked * (totalVitamins - carbos); calcium >= 0; calcium--) { let protein = totalVitamins - (carbos + calcium); let newEff = this.calcBreedingEfficiency([protein, calcium, carbos]); if (newEff > eff) { eff = newEff; optimalVitamins = [protein, calcium, carbos]; } } } // Optimally use vitamins GameHelper.enumNumbers(GameConstants.VitaminType).forEach((v) => { if (this.vitaminsUsed[v]()) { this.removeVitamin(v, Infinity); } if (v < optimalVitamins.length && optimalVitamins[v] > 0) { this.useVitamin(v, optimalVitamins[v]); } }); } } wildPokeNameDisabled(loadSetting('wildPokeNameDisabled', false)); wildPokeDefeatDisabled(loadSetting('wildPokeDefeatDisabled', false)); wildPokeImgDisabled(loadSetting('wildPokeImgDisabled', false)); wildPokeHealthDisabled(loadSetting('wildPokeHealthDisabled', false)); wildPokeCatchDisabled(loadSetting('wildPokeCatchDisabled', false)); avsDisableNotifications = loadSetting('avsDisableNotifications', false); function loadSetting(key, defaultVal) { var val; try { val = JSON.parse(localStorage.getItem(key)); if (val == null || typeof val !== typeof defaultVal) { throw new Error; } } catch { val = defaultVal; localStorage.setItem(key, defaultVal); } return val; } function loadScript(){ const oldInit = Preload.hideSplashScreen; var hasInitialized = false; Preload.hideSplashScreen = function (...args) { var result = oldInit.apply(this, args) if (App.game && !hasInitialized) { initVisualSettings(); hasInitialized = true; } return result; } addGraphicsBindings(); addOptimizeVitamins(); } 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); } loadScript(); ``` Which works fine :

image


Oak Items Unlimited

This one seems to be broken. A variable is used but never defined. You can fill a bug on Ephonia's side for this, I will not help perform actions that the game would not allow.

Here is the content anyway (click to show what to put in the Script content) ```js // ==UserScript== // @name [Pokeclicker] Oak Items Unlimited // @namespace Pokeclicker Scripts // @author Ephenia // @description Removes the limit for the amount of Oak Items that you're able to equip so that you're able to equip all of them. // @copyright https://github.com/Ephenia // @license GPL-3.0 License // @version 1.0 // @homepageURL https://github.com/Ephenia/Pokeclicker-Scripts/ // @supportURL https://github.com/Ephenia/Pokeclicker-Scripts/issues // @downloadURL https://raw.githubusercontent.com/Ephenia/Pokeclicker-Scripts/master/custom/oakitemsunlimited.user.js // @updateURL https://raw.githubusercontent.com/Ephenia/Pokeclicker-Scripts/master/custom/oakitemsunlimited.user.js // @match https://www.pokeclicker.com/ // @icon https://www.google.com/s2/favicons?domain=pokeclicker.com // @grant none // @run-at document-idle // ==/UserScript== var scriptName = 'oakitemsunlimited'; function initOakItems() { var oakItems = App.game.oakItems var oakMax = oakItems.itemList.length; for (let i = 0; i < oakMax; i++) { oakItems.unlockRequirements[i] = 0; } oakItems.maxActiveCount(oakMax); document.getElementById('oakItemsModal').querySelector('h5').innerHTML = "Oak Items Equipped: " + oakItems.activeCount() + '/' + oakMax; } function loadScript() { const oldInit = Preload.hideSplashScreen; hasInitialized = false; Preload.hideSplashScreen = function (...args) { var result = oldInit.apply(this, args); if (App.game && !hasInitialized) { initOakItems(); hasInitialized = true; } return result; } } loadScript(); ```

You can copy the content of each snippet by clicking the image image

Farigh commented 1 year ago

I changed the code evaluation method via #23 This new method is more secure and is less strict on JS syntaxe, which should address the broken script problem

The update should dispatch automatically to your system, once merged

roxieraven327 commented 1 year ago

im so so sorry i didnt get a chance to come back to this after your explanation! work had me very busy lately!!! thank you so much!!!!