From 937cb3492022f9cd313220e2236007e5cc4aaccd Mon Sep 17 00:00:00 2001 From: Aktanusa Date: Fri, 26 Oct 2018 11:31:04 -0400 Subject: [PATCH 1/3] Changed how editing sound URLs to be better (aka you don't need to change the URL and save within the 10 second refresh window anymore) --- CookieMonster.js | 14 ++++++++++---- src/Disp.js | 14 ++++++++++---- 2 files changed, 20 insertions(+), 8 deletions(-) diff --git a/CookieMonster.js b/CookieMonster.js index feed6a6..52fac62 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -1569,14 +1569,20 @@ CM.Disp.AddMenuPref = function(title) { input.id = CM.ConfigPrefix + config; input.className = 'option'; input.type = 'text'; - input.value = CM.Config[config]; + input.readOnly = true; + input.setAttribute('value', CM.Config[config]); input.style.width = '300px'; div.appendChild(input); div.appendChild(document.createTextNode(' ')); + var inputPrompt = document.createElement('input'); + inputPrompt.id = CM.ConfigPrefix + config + 'Prompt'; + inputPrompt.className = 'option'; + inputPrompt.type = 'text'; + inputPrompt.setAttribute('value', CM.Config[config]); var a = document.createElement('a'); a.className = 'option'; - a.onclick = function() {CM.Config[config] = l(CM.ConfigPrefix + config).value;CM.SaveConfig(CM.Config);}; - a.textContent = 'Save'; + a.onclick = function() {Game.Prompt(inputPrompt.outerHTML, [['Save', 'CM.Config[\'' + config + '\'] = l(CM.ConfigPrefix + \'' + config + '\' + \'Prompt\').value; CM.SaveConfig(CM.Config); Game.ClosePrompt(); Game.UpdateMenu();'], 'Cancel']);}; + a.textContent = 'Edit'; div.appendChild(a); var label = document.createElement('label'); label.textContent = CM.ConfigData[config].desc; @@ -1598,7 +1604,7 @@ CM.Disp.AddMenuPref = function(title) { input.id = CM.ConfigPrefix + 'Color' + CM.Disp.colors[i]; input.className = 'option'; input.style.width = '65px'; - input.value = CM.Config.Colors[CM.Disp.colors[i]]; + input.setAttribute('value', CM.Config.Colors[CM.Disp.colors[i]]); div.appendChild(input); eval('var change = function() {CM.Config.Colors[\'' + CM.Disp.colors[i] + '\'] = l(CM.ConfigPrefix + \'Color\' + \'' + CM.Disp.colors[i] + '\').value; CM.Disp.UpdateColors(); CM.SaveConfig(CM.Config);}'); var jscolorpicker = new jscolor.color(input, {hash: true, caps: false, pickerZIndex: 1000000, pickerPosition: 'right', onImmediateChange: change}); diff --git a/src/Disp.js b/src/Disp.js index ed59071..98d6715 100644 --- a/src/Disp.js +++ b/src/Disp.js @@ -1015,14 +1015,20 @@ CM.Disp.AddMenuPref = function(title) { input.id = CM.ConfigPrefix + config; input.className = 'option'; input.type = 'text'; - input.value = CM.Config[config]; + input.readOnly = true; + input.setAttribute('value', CM.Config[config]); input.style.width = '300px'; div.appendChild(input); div.appendChild(document.createTextNode(' ')); + var inputPrompt = document.createElement('input'); + inputPrompt.id = CM.ConfigPrefix + config + 'Prompt'; + inputPrompt.className = 'option'; + inputPrompt.type = 'text'; + inputPrompt.setAttribute('value', CM.Config[config]); var a = document.createElement('a'); a.className = 'option'; - a.onclick = function() {CM.Config[config] = l(CM.ConfigPrefix + config).value;CM.SaveConfig(CM.Config);}; - a.textContent = 'Save'; + a.onclick = function() {Game.Prompt(inputPrompt.outerHTML, [['Save', 'CM.Config[\'' + config + '\'] = l(CM.ConfigPrefix + \'' + config + '\' + \'Prompt\').value; CM.SaveConfig(CM.Config); Game.ClosePrompt(); Game.UpdateMenu();'], 'Cancel']);}; + a.textContent = 'Edit'; div.appendChild(a); var label = document.createElement('label'); label.textContent = CM.ConfigData[config].desc; @@ -1044,7 +1050,7 @@ CM.Disp.AddMenuPref = function(title) { input.id = CM.ConfigPrefix + 'Color' + CM.Disp.colors[i]; input.className = 'option'; input.style.width = '65px'; - input.value = CM.Config.Colors[CM.Disp.colors[i]]; + input.setAttribute('value', CM.Config.Colors[CM.Disp.colors[i]]); div.appendChild(input); eval('var change = function() {CM.Config.Colors[\'' + CM.Disp.colors[i] + '\'] = l(CM.ConfigPrefix + \'Color\' + \'' + CM.Disp.colors[i] + '\').value; CM.Disp.UpdateColors(); CM.SaveConfig(CM.Config);}'); var jscolorpicker = new jscolor.color(input, {hash: true, caps: false, pickerZIndex: 1000000, pickerPosition: 'right', onImmediateChange: change}); From cd3061f2c4f83fb0e243df5e51e5aeefbe1c5464 Mon Sep 17 00:00:00 2001 From: Aktanusa Date: Fri, 26 Oct 2018 11:33:57 -0400 Subject: [PATCH 2/3] Change to Version 2.016.1 --- CookieMonster.js | 4 ++-- src/Main.js | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/CookieMonster.js b/CookieMonster.js index 52fac62..2e07075 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -2816,8 +2816,8 @@ CM.HasReplaceNativeGrimoireDraw = false; CM.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkBuildColor: 0, UpBarColor: 1, CalcWrink: 0, CPSMode: 1, AvgCPSHist: 3, AvgClicksHist: 0, ToolWarnCautBon: 0, Flash: 1, Sound: 1, Volume: 100, GCSoundURL: 'https://freesound.org/data/previews/66/66717_931655-lq.mp3', SeaSoundURL: 'https://www.freesound.org/data/previews/121/121099_2193266-lq.mp3', GCTimer: 1, Title: 1, Favicon: 1, TooltipBuildUp: 1, TooltipAmor: 0, ToolWarnCaut: 1, ToolWarnCautPos: 1, TooltipGrim:1, ToolWrink: 1, Stats: 1, UpStats: 1, TimeFormat: 0, SayTime: 1, GrimoireBar: 1, Scale: 2, StatsPref: {Lucky: 1, Chain: 1, Prestige: 1, Wrink: 1, Sea: 1, Misc: 1}, Colors : {Blue: '#4bb8f0', Green: '#00ff00', Yellow: '#ffff00', Orange: '#ff7f00', Red: '#ff0000', Purple: '#ff00ff', Gray: '#b3b3b3', Pink: '#ff1493', Brown: '#8b4513'}}; CM.ConfigPrefix = 'CMConfig'; -CM.VersionMajor = '2.012'; -CM.VersionMinor = '2'; +CM.VersionMajor = '2.016'; +CM.VersionMinor = '1'; /******* * Sim * diff --git a/src/Main.js b/src/Main.js index 39f7f82..944187a 100644 --- a/src/Main.js +++ b/src/Main.js @@ -247,6 +247,6 @@ CM.HasReplaceNativeGrimoireDraw = false; CM.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkBuildColor: 0, UpBarColor: 1, CalcWrink: 0, CPSMode: 1, AvgCPSHist: 3, AvgClicksHist: 0, ToolWarnCautBon: 0, Flash: 1, Sound: 1, Volume: 100, GCSoundURL: 'https://freesound.org/data/previews/66/66717_931655-lq.mp3', SeaSoundURL: 'https://www.freesound.org/data/previews/121/121099_2193266-lq.mp3', GCTimer: 1, Title: 1, Favicon: 1, TooltipBuildUp: 1, TooltipAmor: 0, ToolWarnCaut: 1, ToolWarnCautPos: 1, TooltipGrim:1, ToolWrink: 1, Stats: 1, UpStats: 1, TimeFormat: 0, SayTime: 1, GrimoireBar: 1, Scale: 2, StatsPref: {Lucky: 1, Chain: 1, Prestige: 1, Wrink: 1, Sea: 1, Misc: 1}, Colors : {Blue: '#4bb8f0', Green: '#00ff00', Yellow: '#ffff00', Orange: '#ff7f00', Red: '#ff0000', Purple: '#ff00ff', Gray: '#b3b3b3', Pink: '#ff1493', Brown: '#8b4513'}}; CM.ConfigPrefix = 'CMConfig'; -CM.VersionMajor = '2.012'; -CM.VersionMinor = '2'; +CM.VersionMajor = '2.016'; +CM.VersionMinor = '1'; From 4a8c59a3e6ad471cde8be8325fe0d87728f7ef88 Mon Sep 17 00:00:00 2001 From: Aktanusa Date: Sat, 27 Oct 2018 20:37:27 -0400 Subject: [PATCH 3/3] Fixed to work with Version 2.016 of Cookie Clicker (Issue #224 & #225) --- CookieMonster.js | 36 ++++++++++++++++-------------------- src/Disp.js | 2 +- src/Sim.js | 34 +++++++++++++++------------------- 3 files changed, 32 insertions(+), 40 deletions(-) diff --git a/CookieMonster.js b/CookieMonster.js index 2e07075..80ea6ae 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -2219,7 +2219,7 @@ CM.Disp.Tooltip = function(type, name) { } else if (type == 'u') { if (!Game.UpgradesInStore[name]) return ''; - l('tooltip').innerHTML = Game.crate(Game.UpgradesInStore[name], 'store', undefined, undefined, 1)(); + l('tooltip').innerHTML = Game.crateTooltip(Game.UpgradesInStore[name], 'store'); } else { // Grimoire l('tooltip').innerHTML = Game.Objects['Wizard tower'].minigame.spellTooltip(name)(); @@ -2906,9 +2906,7 @@ CM.Sim.hasAura = function(what) { return false; } -eval('CM.Sim.GetTieredCpsMult = ' + Game.GetTieredCpsMult.toString().split('Game.Has').join('CM.Sim.Has').split('me.tieredUpgrades').join('Game.Objects[me.name].tieredUpgrades').split('me.synergies').join('Game.Objects[me.name].synergies').split('syn.buildingTie1.amount').join('CM.Sim.Objects[syn.buildingTie1.name].amount').split('syn.buildingTie2.amount').join('CM.Sim.Objects[syn.buildingTie2.name].amount')); - -eval('CM.Sim.getGrandmaSynergyUpgradeMultiplier = ' + Game.getGrandmaSynergyUpgradeMultiplier.toString().split('Game.Objects[\'Grandma\']').join('CM.Sim.Objects[\'Grandma\']')); +eval('CM.Sim.GetTieredCpsMult = ' + Game.GetTieredCpsMult.toString().split('Game.Has').join('CM.Sim.Has').split('me.tieredUpgrades').join('Game.Objects[me.name].tieredUpgrades').split('me.synergies').join('Game.Objects[me.name].synergies').split('syn.buildingTie1.amount').join('CM.Sim.Objects[syn.buildingTie1.name].amount').split('syn.buildingTie2.amount').join('CM.Sim.Objects[syn.buildingTie2.name].amount').split('me.grandma').join('Game.Objects[me.name].grandma').split('me.id').join('Game.Objects[me.name].id').split('Game.Objects[\'Grandma\']').join('CM.Sim.Objects[\'Grandma\']')); CM.Sim.getCPSBuffMult = function() { var mult = 1; @@ -2925,7 +2923,7 @@ CM.Sim.InitData = function() { CM.Sim.Objects[i] = {}; var me = Game.Objects[i]; var you = CM.Sim.Objects[i]; - eval('you.cps = ' + me.cps.toString().split('Game.Has').join('CM.Sim.Has').split('Game.hasAura').join('CM.Sim.hasAura').split('Game.Objects').join('CM.Sim.Objects').split('Game.GetTieredCpsMult').join('CM.Sim.GetTieredCpsMult').split('Game.getGrandmaSynergyUpgradeMultiplier').join('CM.Sim.getGrandmaSynergyUpgradeMultiplier')); + eval('you.cps = ' + me.cps.toString().split('Game.Has').join('CM.Sim.Has').split('Game.hasAura').join('CM.Sim.hasAura').split('Game.Objects').join('CM.Sim.Objects').split('Game.GetTieredCpsMult').join('CM.Sim.GetTieredCpsMult')); // Below is needed for above eval! you.baseCps = me.baseCps; you.name = me.name; @@ -2981,11 +2979,13 @@ CM.Sim.CopyData = function() { CM.Sim.CalculateGains = function() { CM.Sim.cookiesPs = 0; var mult = 1; - + if (Game.ascensionMode != 1) mult += parseFloat(CM.Sim.prestige) * 0.01 * CM.Sim.heavenlyPower * CM.Sim.GetHeavenlyMultiplier(); // TODO Store minigame buffs? mult *= Game.eff('cps'); + + if (CM.Sim.Has('Heralds') && Game.ascensionMode != 1) mult *= 1 + 0.01 * Game.heralds; var cookieMult = 0; for (var i in Game.cookieUpgrades) { @@ -3129,13 +3129,17 @@ CM.Sim.CalculateGains = function() { if (CM.Sim.Has('Golden switch [off]')) { var goldenSwitchMult = 1.5; if (CM.Sim.Has('Residual luck')) { - var upgrades = ['Get lucky', 'Lucky day', 'Serendipity', 'Heavenly luck', 'Lasting fortune', 'Decisive fate', 'Lucky digit', 'Lucky number', 'Lucky payout']; + var upgrades = Game.goldenCookieUpgrades; for (var i in upgrades) { if (CM.Sim.Has(upgrades[i])) goldenSwitchMult += 0.1; } } mult *= goldenSwitchMult; } + if (CM.Sim.Has('Shimmering veil [off]')) mult *= 1.5; + // Removed debug upgrades + + // Removed buffs CM.Sim.cookiesPs *= mult; @@ -3145,20 +3149,11 @@ CM.Sim.CalculateGains = function() { CM.Sim.CheckOtherAchiev = function() { var grandmas = 0; - if (CM.Sim.Has('Farmer grandmas')) grandmas++; - if (CM.Sim.Has('Worker grandmas')) grandmas++; - if (CM.Sim.Has('Miner grandmas')) grandmas++; - if (CM.Sim.Has('Cosmic grandmas')) grandmas++; - if (CM.Sim.Has('Transmuted grandmas')) grandmas++; - if (CM.Sim.Has('Altered grandmas')) grandmas++; - if (CM.Sim.Has('Grandmas\' grandmas')) grandmas++; - if (CM.Sim.Has('Antigrandmas')) grandmas++; - if (CM.Sim.Has('Rainbow grandmas')) grandmas++; - if (CM.Sim.Has('Banker grandmas')) grandmas++; - if (CM.Sim.Has('Priestess grandmas')) grandmas++; - if (CM.Sim.Has('Witch grandmas')) grandmas++; - if (CM.Sim.Has('Lucky grandmas')) grandmas++; + for (var i in Game.GrandmaSynergies) { + if (CM.Sim.Has(Game.GrandmaSynergies[i])) grandmas++; + } if (!CM.Sim.HasAchiev('Elder') && grandmas >= 7) CM.Sim.Win('Elder'); + if (!CM.Sim.HasAchiev('Veteran') && grandmas >= 14) CM.Sim.Win('Veteran'); var buildingsOwned = 0; var mathematician = 1; @@ -3198,6 +3193,7 @@ CM.Sim.CheckOtherAchiev = function() { if (CM.Sim.UpgradesOwned >= 200) CM.Sim.Win('Lord of Progress'); if (buildingsOwned >= 3000 && CM.Sim.UpgradesOwned >= 300) CM.Sim.Win('Polymath'); + if (buildingsOwned >= 4000 && CM.Sim.UpgradesOwned >= 400) CM.Sim.Win('Renaissance baker'); if (CM.Sim.Objects['Cursor'].amount + CM.Sim.Objects['Grandma'].amount >= 777) CM.Sim.Win('The elder scrolls'); diff --git a/src/Disp.js b/src/Disp.js index 98d6715..8eeafe4 100644 --- a/src/Disp.js +++ b/src/Disp.js @@ -1665,7 +1665,7 @@ CM.Disp.Tooltip = function(type, name) { } else if (type == 'u') { if (!Game.UpgradesInStore[name]) return ''; - l('tooltip').innerHTML = Game.crate(Game.UpgradesInStore[name], 'store', undefined, undefined, 1)(); + l('tooltip').innerHTML = Game.crateTooltip(Game.UpgradesInStore[name], 'store'); } else { // Grimoire l('tooltip').innerHTML = Game.Objects['Wizard tower'].minigame.spellTooltip(name)(); diff --git a/src/Sim.js b/src/Sim.js index 302e893..8686781 100644 --- a/src/Sim.js +++ b/src/Sim.js @@ -85,9 +85,7 @@ CM.Sim.hasAura = function(what) { return false; } -eval('CM.Sim.GetTieredCpsMult = ' + Game.GetTieredCpsMult.toString().split('Game.Has').join('CM.Sim.Has').split('me.tieredUpgrades').join('Game.Objects[me.name].tieredUpgrades').split('me.synergies').join('Game.Objects[me.name].synergies').split('syn.buildingTie1.amount').join('CM.Sim.Objects[syn.buildingTie1.name].amount').split('syn.buildingTie2.amount').join('CM.Sim.Objects[syn.buildingTie2.name].amount')); - -eval('CM.Sim.getGrandmaSynergyUpgradeMultiplier = ' + Game.getGrandmaSynergyUpgradeMultiplier.toString().split('Game.Objects[\'Grandma\']').join('CM.Sim.Objects[\'Grandma\']')); +eval('CM.Sim.GetTieredCpsMult = ' + Game.GetTieredCpsMult.toString().split('Game.Has').join('CM.Sim.Has').split('me.tieredUpgrades').join('Game.Objects[me.name].tieredUpgrades').split('me.synergies').join('Game.Objects[me.name].synergies').split('syn.buildingTie1.amount').join('CM.Sim.Objects[syn.buildingTie1.name].amount').split('syn.buildingTie2.amount').join('CM.Sim.Objects[syn.buildingTie2.name].amount').split('me.grandma').join('Game.Objects[me.name].grandma').split('me.id').join('Game.Objects[me.name].id').split('Game.Objects[\'Grandma\']').join('CM.Sim.Objects[\'Grandma\']')); CM.Sim.getCPSBuffMult = function() { var mult = 1; @@ -104,7 +102,7 @@ CM.Sim.InitData = function() { CM.Sim.Objects[i] = {}; var me = Game.Objects[i]; var you = CM.Sim.Objects[i]; - eval('you.cps = ' + me.cps.toString().split('Game.Has').join('CM.Sim.Has').split('Game.hasAura').join('CM.Sim.hasAura').split('Game.Objects').join('CM.Sim.Objects').split('Game.GetTieredCpsMult').join('CM.Sim.GetTieredCpsMult').split('Game.getGrandmaSynergyUpgradeMultiplier').join('CM.Sim.getGrandmaSynergyUpgradeMultiplier')); + eval('you.cps = ' + me.cps.toString().split('Game.Has').join('CM.Sim.Has').split('Game.hasAura').join('CM.Sim.hasAura').split('Game.Objects').join('CM.Sim.Objects').split('Game.GetTieredCpsMult').join('CM.Sim.GetTieredCpsMult')); // Below is needed for above eval! you.baseCps = me.baseCps; you.name = me.name; @@ -160,11 +158,13 @@ CM.Sim.CopyData = function() { CM.Sim.CalculateGains = function() { CM.Sim.cookiesPs = 0; var mult = 1; - + if (Game.ascensionMode != 1) mult += parseFloat(CM.Sim.prestige) * 0.01 * CM.Sim.heavenlyPower * CM.Sim.GetHeavenlyMultiplier(); // TODO Store minigame buffs? mult *= Game.eff('cps'); + + if (CM.Sim.Has('Heralds') && Game.ascensionMode != 1) mult *= 1 + 0.01 * Game.heralds; var cookieMult = 0; for (var i in Game.cookieUpgrades) { @@ -308,13 +308,17 @@ CM.Sim.CalculateGains = function() { if (CM.Sim.Has('Golden switch [off]')) { var goldenSwitchMult = 1.5; if (CM.Sim.Has('Residual luck')) { - var upgrades = ['Get lucky', 'Lucky day', 'Serendipity', 'Heavenly luck', 'Lasting fortune', 'Decisive fate', 'Lucky digit', 'Lucky number', 'Lucky payout']; + var upgrades = Game.goldenCookieUpgrades; for (var i in upgrades) { if (CM.Sim.Has(upgrades[i])) goldenSwitchMult += 0.1; } } mult *= goldenSwitchMult; } + if (CM.Sim.Has('Shimmering veil [off]')) mult *= 1.5; + // Removed debug upgrades + + // Removed buffs CM.Sim.cookiesPs *= mult; @@ -324,20 +328,11 @@ CM.Sim.CalculateGains = function() { CM.Sim.CheckOtherAchiev = function() { var grandmas = 0; - if (CM.Sim.Has('Farmer grandmas')) grandmas++; - if (CM.Sim.Has('Worker grandmas')) grandmas++; - if (CM.Sim.Has('Miner grandmas')) grandmas++; - if (CM.Sim.Has('Cosmic grandmas')) grandmas++; - if (CM.Sim.Has('Transmuted grandmas')) grandmas++; - if (CM.Sim.Has('Altered grandmas')) grandmas++; - if (CM.Sim.Has('Grandmas\' grandmas')) grandmas++; - if (CM.Sim.Has('Antigrandmas')) grandmas++; - if (CM.Sim.Has('Rainbow grandmas')) grandmas++; - if (CM.Sim.Has('Banker grandmas')) grandmas++; - if (CM.Sim.Has('Priestess grandmas')) grandmas++; - if (CM.Sim.Has('Witch grandmas')) grandmas++; - if (CM.Sim.Has('Lucky grandmas')) grandmas++; + for (var i in Game.GrandmaSynergies) { + if (CM.Sim.Has(Game.GrandmaSynergies[i])) grandmas++; + } if (!CM.Sim.HasAchiev('Elder') && grandmas >= 7) CM.Sim.Win('Elder'); + if (!CM.Sim.HasAchiev('Veteran') && grandmas >= 14) CM.Sim.Win('Veteran'); var buildingsOwned = 0; var mathematician = 1; @@ -377,6 +372,7 @@ CM.Sim.CheckOtherAchiev = function() { if (CM.Sim.UpgradesOwned >= 200) CM.Sim.Win('Lord of Progress'); if (buildingsOwned >= 3000 && CM.Sim.UpgradesOwned >= 300) CM.Sim.Win('Polymath'); + if (buildingsOwned >= 4000 && CM.Sim.UpgradesOwned >= 400) CM.Sim.Win('Renaissance baker'); if (CM.Sim.Objects['Cursor'].amount + CM.Sim.Objects['Grandma'].amount >= 777) CM.Sim.Win('The elder scrolls');