From 9df807a4aea688c18ddca9618a1160fb22339171 Mon Sep 17 00:00:00 2001 From: Aktanusa Date: Wed, 13 Sep 2017 09:32:44 -0400 Subject: [PATCH 01/18] Version change to 2.0042.3 --- CookieMonster.js | 2 +- src/Main.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/CookieMonster.js b/CookieMonster.js index 34b2844..7106ce9 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -2749,7 +2749,7 @@ CM.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkB CM.ConfigPrefix = 'CMConfig'; CM.VersionMajor = '2.0042'; -CM.VersionMinor = '2'; +CM.VersionMinor = '3'; /******* * Sim * diff --git a/src/Main.js b/src/Main.js index f4ba933..335dd2b 100644 --- a/src/Main.js +++ b/src/Main.js @@ -251,5 +251,5 @@ CM.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkB CM.ConfigPrefix = 'CMConfig'; CM.VersionMajor = '2.0042'; -CM.VersionMinor = '2'; +CM.VersionMinor = '3'; From f32b1d568570809e07754515f41177905b0c7d23 Mon Sep 17 00:00:00 2001 From: Aktanusa Date: Wed, 13 Sep 2017 09:35:10 -0400 Subject: [PATCH 02/18] Fix tooltip toggle description --- CookieMonster.js | 2 +- src/Config.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/CookieMonster.js b/CookieMonster.js index 7106ce9..77a4beb 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -529,7 +529,7 @@ CM.ConfigData.SeaSoundURL = {label: 'Season Special Sound URL:', desc: 'URL of t CM.ConfigData.GCTimer = {label: ['Golden Cookie Timer OFF', 'Golden Cookie Timer ON'], desc: 'A timer on the Golden Cookie when it has been spawned', toggle: true, func: function() {CM.Disp.ToggleGCTimer();}}; CM.ConfigData.Title = {label: ['Title OFF', 'Title ON', 'Title Pinned Tab Highlight'], desc: 'Update title with Golden Cookie/Season Popup timers; pinned tab highlight only changes the title when a Golden Cookie/Season Popup spawns', toggle: true}; CM.ConfigData.Favicon = {label: ['Favicon OFF', 'Favicon ON'], desc: 'Update favicon with Golden/Wrath Cookie', toggle: true, func: function() {CM.Disp.UpdateFavicon();}}; -CM.ConfigData.Tooltip = {label: ['Tooltip Information OFF', 'Tooltip Information ON'], desc: 'Extra information in tooltip for buildings/upgrades', toggle: true}; +CM.ConfigData.Tooltip = {label: ['Tooltip Information OFF', 'Tooltip Information ON'], desc: 'Extra information in tooltip for buildings/upgrades/grimoire', toggle: true}; CM.ConfigData.TooltipAmor = {label: ['Tooltip Amortization Information OFF', 'Tooltip Amortization Information ON'], desc: 'Add amortization information to buildings tooltip', toggle: true}; CM.ConfigData.ToolWarnCaut = {label: ['Tooltip Warning/Caution OFF', 'Tooltip Warning/Caution ON'], desc: 'A warning/caution when buying if it will put the bank under the amount needed for max "Lucky!"/"Lucky!" (Frenzy) rewards', toggle: true, func: function() {CM.Disp.ToggleToolWarnCaut();}}; CM.ConfigData.ToolWarnCautPos = {label: ['Tooltip Warning/Caution Position (Left)', 'Tooltip Warning/Caution Position (Bottom)'], desc: 'Placement of the warning/caution boxes', toggle: false, func: function() {CM.Disp.ToggleToolWarnCautPos();}}; diff --git a/src/Config.js b/src/Config.js index 7f7e59b..cb2940a 100644 --- a/src/Config.js +++ b/src/Config.js @@ -137,7 +137,7 @@ CM.ConfigData.SeaSoundURL = {label: 'Season Special Sound URL:', desc: 'URL of t CM.ConfigData.GCTimer = {label: ['Golden Cookie Timer OFF', 'Golden Cookie Timer ON'], desc: 'A timer on the Golden Cookie when it has been spawned', toggle: true, func: function() {CM.Disp.ToggleGCTimer();}}; CM.ConfigData.Title = {label: ['Title OFF', 'Title ON', 'Title Pinned Tab Highlight'], desc: 'Update title with Golden Cookie/Season Popup timers; pinned tab highlight only changes the title when a Golden Cookie/Season Popup spawns', toggle: true}; CM.ConfigData.Favicon = {label: ['Favicon OFF', 'Favicon ON'], desc: 'Update favicon with Golden/Wrath Cookie', toggle: true, func: function() {CM.Disp.UpdateFavicon();}}; -CM.ConfigData.Tooltip = {label: ['Tooltip Information OFF', 'Tooltip Information ON'], desc: 'Extra information in tooltip for buildings/upgrades', toggle: true}; +CM.ConfigData.Tooltip = {label: ['Tooltip Information OFF', 'Tooltip Information ON'], desc: 'Extra information in tooltip for buildings/upgrades/grimoire', toggle: true}; CM.ConfigData.TooltipAmor = {label: ['Tooltip Amortization Information OFF', 'Tooltip Amortization Information ON'], desc: 'Add amortization information to buildings tooltip', toggle: true}; CM.ConfigData.ToolWarnCaut = {label: ['Tooltip Warning/Caution OFF', 'Tooltip Warning/Caution ON'], desc: 'A warning/caution when buying if it will put the bank under the amount needed for max "Lucky!"/"Lucky!" (Frenzy) rewards', toggle: true, func: function() {CM.Disp.ToggleToolWarnCaut();}}; CM.ConfigData.ToolWarnCautPos = {label: ['Tooltip Warning/Caution Position (Left)', 'Tooltip Warning/Caution Position (Bottom)'], desc: 'Placement of the warning/caution boxes', toggle: false, func: function() {CM.Disp.ToggleToolWarnCautPos();}}; From 816c566442c1a037a0468563ff6b3ee3fa49c9f5 Mon Sep 17 00:00:00 2001 From: Laurent Georget Date: Thu, 9 Mar 2017 15:21:51 +0100 Subject: [PATCH 03/18] Add the 'next multiple of 50' information to buildings' tooltip --- src/Cache.js | 8 ++++++++ src/Config.js | 1 + src/Disp.js | 13 ++++++++++++- src/Main.js | 6 +++++- 4 files changed, 26 insertions(+), 2 deletions(-) diff --git a/src/Cache.js b/src/Cache.js index 39c4ae3..adcf847 100644 --- a/src/Cache.js +++ b/src/Cache.js @@ -133,6 +133,14 @@ CM.Cache.RemakePP = function() { CM.Cache.RemakeBuildingsOtherPP(100, 'Objects100'); } +CM.Cache.RemakeMultiple = function () { + for (var i in CM.Cache.Objects) { + var nextMultiple = 50 - Game.Objects[i].amount % 50; + CM.Cache.Objects[i].multiple_quantity = nextMultiple; + CM.Cache.Objects[i].multiple_price = CM.Sim.BuildingGetPrice(Game.Objects[i].basePrice, Game.Objects[i].amount, Game.Objects[i].free, nextMultiple); + } +} + CM.Cache.RemakeLucky = function() { CM.Cache.Lucky = (CM.Cache.NoGoldSwitchCookiesPS * 60 * 15) / 0.15; CM.Cache.Lucky /= CM.Sim.getCPSBuffMult(); diff --git a/src/Config.js b/src/Config.js index cb2940a..0b2dcbf 100644 --- a/src/Config.js +++ b/src/Config.js @@ -139,6 +139,7 @@ CM.ConfigData.Title = {label: ['Title OFF', 'Title ON', 'Title Pinned Tab Highli CM.ConfigData.Favicon = {label: ['Favicon OFF', 'Favicon ON'], desc: 'Update favicon with Golden/Wrath Cookie', toggle: true, func: function() {CM.Disp.UpdateFavicon();}}; CM.ConfigData.Tooltip = {label: ['Tooltip Information OFF', 'Tooltip Information ON'], desc: 'Extra information in tooltip for buildings/upgrades/grimoire', toggle: true}; CM.ConfigData.TooltipAmor = {label: ['Tooltip Amortization Information OFF', 'Tooltip Amortization Information ON'], desc: 'Add amortization information to buildings tooltip', toggle: true}; +CM.ConfigData.TooltipNextMultiple = {label: ['Tooltip Next Multiple of 50 Information OFF', 'Tooltip Next Multiple of 50 Information ON'], desc: 'Add the total price necessary to reach the next multiple of 50 buildings of a kind to buildings tooltip', toggle: true}; CM.ConfigData.ToolWarnCaut = {label: ['Tooltip Warning/Caution OFF', 'Tooltip Warning/Caution ON'], desc: 'A warning/caution when buying if it will put the bank under the amount needed for max "Lucky!"/"Lucky!" (Frenzy) rewards', toggle: true, func: function() {CM.Disp.ToggleToolWarnCaut();}}; CM.ConfigData.ToolWarnCautPos = {label: ['Tooltip Warning/Caution Position (Left)', 'Tooltip Warning/Caution Position (Bottom)'], desc: 'Placement of the warning/caution boxes', toggle: false, func: function() {CM.Disp.ToggleToolWarnCautPos();}}; CM.ConfigData.ToolWrink = {label: ['Wrinkler Tooltip OFF', 'Wrinkler Tooltip ON'], desc: 'Shows the amount of cookies a wrinkler will give when popping it', toggle: true}; diff --git a/src/Disp.js b/src/Disp.js index a91aab5..d8807ab 100644 --- a/src/Disp.js +++ b/src/Disp.js @@ -1047,6 +1047,7 @@ CM.Disp.AddMenuPref = function(title) { frag.appendChild(header('Tooltip')); frag.appendChild(listing('Tooltip')); frag.appendChild(listing('TooltipAmor')); + frag.appendChild(listing('TooltipNextMultiple')); frag.appendChild(listing('ToolWarnCaut')); frag.appendChild(listing('ToolWarnCautPos')); frag.appendChild(listing('ToolWrink')); @@ -1565,13 +1566,23 @@ CM.Disp.AddTooltipGrimoire = function() { CM.Disp.Tooltip = function(type, name) { if (type == 'b') { l('tooltip').innerHTML = Game.Objects[name].tooltip(); + var addedAmor = false; + if (CM.Config.TooltipAmor == 1) { var buildPrice = CM.Sim.BuildingGetPrice(Game.Objects[name].basePrice, 0, Game.Objects[name].free, Game.Objects[name].amount); var amortizeAmount = buildPrice - Game.Objects[name].totalCookies; if (amortizeAmount > 0) { - l('tooltip').innerHTML = l('tooltip').innerHTML.split('so far').join('so far
' + Beautify(amortizeAmount) + ' ' + (Math.floor(amortizeAmount) == 1 ? 'cookie' : 'cookies') + ' left to amortize (' + CM.Disp.GetTimeColor(buildPrice, Game.Objects[name].totalCookies, (Game.Objects[name].storedTotalCps * Game.globalCpsMult)).text + ')'); + addedAmor = true; + l('tooltip').innerHTML = l('tooltip').innerHTML.split('so far').join('so far
' + Beautify(amortizeAmount) + ' ' + (Math.floor(amortizeAmount) == 1 ? 'cookie' : 'cookies') + ' left to amortize (' + CM.Disp.GetTimeColor(buildPrice, Game.Objects[name].totalCookies, (Game.Objects[name].storedTotalCps * Game.globalCpsMult)).text + ')'); } } + + if (CM.Config.TooltipNextMultiple == 1) { + var marker = addedAmor ? ')' : 'so far'; + var multiple_quantity = CM.Cache.Objects[name].multiple_quantity; + l('tooltip').innerHTML = l('tooltip').innerHTML.split(marker + '').join(marker + '
' + multiple_quantity + ' left to reach ' + (Game.Objects[name].amount + multiple_quantity) + ', ' + Beautify(CM.Cache.Objects[name].multiple_price, 2) + ' in total'); + } + if (Game.buyMode == 1) { var target = ''; var change = false; diff --git a/src/Main.js b/src/Main.js index 335dd2b..5ab37a0 100644 --- a/src/Main.js +++ b/src/Main.js @@ -162,6 +162,10 @@ CM.Loop = function() { // Calculate PP CM.Cache.RemakePP(); + // Calculate total price until reaching next multiple of 50 + // for each building + CM.Cache.RemakeMultiple(); + // Update colors CM.Disp.UpdateBotBarOther(); CM.Disp.UpdateBuildings(); @@ -247,7 +251,7 @@ CM.DelayInit = function() { CM.HasReplaceNativeGrimoireLaunch = false; CM.HasReplaceNativeGrimoireDraw = false; -CM.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkBuildColor: 0, UpBarColor: 1, CalcWrink: 0, CPSMode: 1, AvgCPSHist: 0, AvgClicksHist: 0, ToolWarnCautBon: 0, Flash: 1, Sound: 1, Volume: 100, GCSoundURL: 'http://freesound.org/data/previews/66/66717_931655-lq.mp3', SeaSoundURL: 'http://www.freesound.org/data/previews/121/121099_2193266-lq.mp3', GCTimer: 1, Title: 1, Favicon: 1, Tooltip: 1, TooltipAmor: 0, ToolWarnCaut: 1, ToolWarnCautPos: 1, ToolWrink: 1, Stats: 1, UpStats: 1, TimeFormat: 0, SayTime: 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.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkBuildColor: 0, UpBarColor: 1, CalcWrink: 0, CPSMode: 1, AvgCPSHist: 0, AvgClicksHist: 0, ToolWarnCautBon: 0, Flash: 1, Sound: 1, Volume: 100, GCSoundURL: 'http://freesound.org/data/previews/66/66717_931655-lq.mp3', SeaSoundURL: 'http://www.freesound.org/data/previews/121/121099_2193266-lq.mp3', GCTimer: 1, Title: 1, Favicon: 1, Tooltip: 1, TooltipAmor: 0, TooltipNextMultiple: 0, ToolWarnCaut: 1, ToolWarnCautPos: 1, ToolWrink: 1, Stats: 1, UpStats: 1, TimeFormat: 0, SayTime: 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.0042'; From 010e065dd717b13e3e7a4aa437ec637a4d5eb5f1 Mon Sep 17 00:00:00 2001 From: Laurent Georget Date: Thu, 9 Mar 2017 15:47:14 +0100 Subject: [PATCH 04/18] Add the time left to the 'next multiple' information in buildings' tooltip --- src/Disp.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Disp.js b/src/Disp.js index d8807ab..33a3a07 100644 --- a/src/Disp.js +++ b/src/Disp.js @@ -1580,7 +1580,7 @@ CM.Disp.Tooltip = function(type, name) { if (CM.Config.TooltipNextMultiple == 1) { var marker = addedAmor ? ')' : 'so far'; var multiple_quantity = CM.Cache.Objects[name].multiple_quantity; - l('tooltip').innerHTML = l('tooltip').innerHTML.split(marker + '').join(marker + '
' + multiple_quantity + ' left to reach ' + (Game.Objects[name].amount + multiple_quantity) + ', ' + Beautify(CM.Cache.Objects[name].multiple_price, 2) + ' in total'); + l('tooltip').innerHTML = l('tooltip').innerHTML.split(marker + '').join(marker + '
' + multiple_quantity + ' ' + (multiple_quantity == 1 ? Game.Objects[name].single : Game.Objects[name].plural) + ' left to reach ' + (Game.Objects[name].amount + multiple_quantity) + ', ' + Beautify(CM.Cache.Objects[name].multiple_price, 2) + ' cookies in total (' + CM.Disp.GetTimeColor(CM.Cache.Objects[name].multiple_price, (Game.cookies + CM.Disp.GetWrinkConfigBank()), CM.Disp.GetCPS()).text + ')'); } if (Game.buyMode == 1) { From 0f8b5b7da783f518e3c5292b8d6e214a3c273ddf Mon Sep 17 00:00:00 2001 From: redthefed Date: Fri, 16 Feb 2018 18:53:56 -0600 Subject: [PATCH 05/18] commit --- CookieMonster.js | 187 ++++++++++++++++++++++----------------------- src/Cache.js | 8 -- src/Config.js | 3 +- src/Disp.js | 192 ++++++++++++++++++++++------------------------- src/Main.js | 8 +- 5 files changed, 188 insertions(+), 210 deletions(-) diff --git a/CookieMonster.js b/CookieMonster.js index 77a4beb..45e22d0 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -529,7 +529,7 @@ CM.ConfigData.SeaSoundURL = {label: 'Season Special Sound URL:', desc: 'URL of t CM.ConfigData.GCTimer = {label: ['Golden Cookie Timer OFF', 'Golden Cookie Timer ON'], desc: 'A timer on the Golden Cookie when it has been spawned', toggle: true, func: function() {CM.Disp.ToggleGCTimer();}}; CM.ConfigData.Title = {label: ['Title OFF', 'Title ON', 'Title Pinned Tab Highlight'], desc: 'Update title with Golden Cookie/Season Popup timers; pinned tab highlight only changes the title when a Golden Cookie/Season Popup spawns', toggle: true}; CM.ConfigData.Favicon = {label: ['Favicon OFF', 'Favicon ON'], desc: 'Update favicon with Golden/Wrath Cookie', toggle: true, func: function() {CM.Disp.UpdateFavicon();}}; -CM.ConfigData.Tooltip = {label: ['Tooltip Information OFF', 'Tooltip Information ON'], desc: 'Extra information in tooltip for buildings/upgrades/grimoire', toggle: true}; +CM.ConfigData.Tooltip = {label: ['Tooltip Information OFF', 'Tooltip Information ON'], desc: 'Extra information in tooltip for buildings/upgrades', toggle: true}; CM.ConfigData.TooltipAmor = {label: ['Tooltip Amortization Information OFF', 'Tooltip Amortization Information ON'], desc: 'Add amortization information to buildings tooltip', toggle: true}; CM.ConfigData.ToolWarnCaut = {label: ['Tooltip Warning/Caution OFF', 'Tooltip Warning/Caution ON'], desc: 'A warning/caution when buying if it will put the bank under the amount needed for max "Lucky!"/"Lucky!" (Frenzy) rewards', toggle: true, func: function() {CM.Disp.ToggleToolWarnCaut();}}; CM.ConfigData.ToolWarnCautPos = {label: ['Tooltip Warning/Caution Position (Left)', 'Tooltip Warning/Caution Position (Bottom)'], desc: 'Placement of the warning/caution boxes', toggle: false, func: function() {CM.Disp.ToggleToolWarnCautPos();}}; @@ -584,7 +584,7 @@ CM.Disp.FormatTime = function(time, format) { } str += s; } else { - if (time > 777600000) return format ? 'Over 9000 days!' : '>9000d'; + if (time > 86400) return format ? 'Over 24 hours' : '>24h'; time = Math.ceil(time); var d = Math.floor(time / 86400); var h = Math.floor(time % 86400 / 3600); @@ -614,7 +614,7 @@ CM.Disp.GetTimeColor = function(price, bank, cps, time) { text = '00:00:00:00:00'; } else { - text = 'Done!'; + text = 'Ready'; } } else { @@ -646,7 +646,7 @@ CM.Disp.Beautify = function(num, frac) { num = Math.abs(num); negative = true; } - + for (var i = (CM.Disp.shortScale.length - 1); i >= 0; i--) { if (i < CM.Disp.metric.length && CM.Config.Scale == 1) { if (num >= Math.pow(1000, i + 2)) { @@ -664,7 +664,7 @@ CM.Disp.Beautify = function(num, frac) { if (answer == '') { answer = CM.Backup.Beautify(num, frac); } - + if (negative) { answer = '-' + answer; } @@ -729,14 +729,16 @@ CM.Disp.CreateBotBar = function() { CM.Disp.BotBar.style.borderTop = '1px solid black'; CM.Disp.BotBar.style.overflow = 'auto'; CM.Disp.BotBar.style.textShadow = '-1px 0 black, 0 1px black, 1px 0 black, 0 -1px black'; - + var table = document.createElement('table'); table.style.width = '100%'; table.style.textAlign = 'center'; table.style.whiteSpace = 'nowrap'; + table.style.tableLayout = 'fixed'; + table.style.overflow = 'hidden'; var tbody = document.createElement('tbody'); table.appendChild(tbody); - + var firstCol = function(text, color) { var td = document.createElement('td'); td.style.textAlign = 'right'; @@ -744,7 +746,7 @@ CM.Disp.CreateBotBar = function() { td.textContent = text; return td; } - + var type = document.createElement('tr'); type.style.fontWeight = 'bold'; type.appendChild(firstCol(CM.VersionMajor + '.' + CM.VersionMinor, CM.Disp.colorYellow)); @@ -758,7 +760,7 @@ CM.Disp.CreateBotBar = function() { var time = document.createElement('tr'); time.appendChild(firstCol('Time Left', CM.Disp.colorBlue)); tbody.appendChild(time); - + for (var i in Game.Objects) { var header = document.createElement('td'); header.appendChild(document.createTextNode((i.indexOf(' ') != -1 ? i.substring(0, i.indexOf(' ')) : i) + ' (')); @@ -770,11 +772,11 @@ CM.Disp.CreateBotBar = function() { bonus.appendChild(document.createElement('td')); pp.appendChild(document.createElement('td')); time.appendChild(document.createElement('td')); - + } - + CM.Disp.BotBar.appendChild(table); - + l('wrapper').appendChild(CM.Disp.BotBar); } @@ -792,7 +794,7 @@ CM.Disp.ToggleBotBar = function() { CM.Disp.UpdateBotBarOther = function() { if (CM.Config.BotBar == 1) { var count = 0; - + for (var i in CM.Cache.Objects) { count++; CM.Disp.BotBar.firstChild.firstChild.childNodes[0].childNodes[count].childNodes[1].textContent = Game.Objects[i].amount; @@ -806,7 +808,7 @@ CM.Disp.UpdateBotBarOther = function() { CM.Disp.UpdateBotBarTime = function() { if (CM.Config.BotBar == 1) { var count = 0; - + for (var i in CM.Cache.Objects) { count++; var timeColor = CM.Disp.GetTimeColor(Game.Objects[i].getPrice(), (Game.cookies + CM.Disp.GetWrinkConfigBank()), CM.Disp.GetCPS()); @@ -825,7 +827,7 @@ CM.Disp.CreateTimerBar = function() { CM.Disp.TimerBar.style.fontSize = '10px'; CM.Disp.TimerBar.style.fontWeight = 'bold'; CM.Disp.TimerBar.style.backgroundColor = 'black'; - + var bar = function(name, bars, time) { var div = document.createElement('div'); div.style.width = '100%'; @@ -836,7 +838,7 @@ CM.Disp.CreateTimerBar = function() { div.style.top = '0px'; div.style.right = '0px'; div.style.bottom = '0px'; - + var type = document.createElement('span'); type.style.display = 'inline-block'; type.style.textAlign = 'right'; @@ -845,7 +847,7 @@ CM.Disp.CreateTimerBar = function() { type.style.verticalAlign = 'text-top'; type.textContent = name; div.appendChild(type); - + for (var i = 0; i < bars.length; i++) { var colorBar = document.createElement('span'); colorBar.id = bars[i].id @@ -860,7 +862,7 @@ CM.Disp.CreateTimerBar = function() { } div.appendChild(colorBar); } - + var timer = document.createElement('span'); timer.id = time; timer.style.marginLeft = '5px'; @@ -868,7 +870,7 @@ CM.Disp.CreateTimerBar = function() { div.appendChild(timer); return div } - + CM.Disp.TimerBarGC = document.createElement('div'); CM.Disp.TimerBarGC.id = 'CMTimerBarGC'; CM.Disp.TimerBarGC.style.height = '12px'; @@ -876,7 +878,7 @@ CM.Disp.CreateTimerBar = function() { CM.Disp.TimerBarGC.style.position = 'relative'; CM.Disp.TimerBarGC.appendChild(bar('Next Cookie', [{id: 'CMTimerBarGCMinBar', color: CM.Disp.colorGray}, {id: 'CMTimerBarGCBar', color: CM.Disp.colorPurple}], 'CMTimerBarGCTime')); CM.Disp.TimerBar.appendChild(CM.Disp.TimerBarGC); - + CM.Disp.TimerBarRen = document.createElement('div'); CM.Disp.TimerBarRen.id = 'CMTimerBarRen'; CM.Disp.TimerBarRen.style.height = '12px'; @@ -884,7 +886,7 @@ CM.Disp.CreateTimerBar = function() { CM.Disp.TimerBarRen.style.position = 'relative'; CM.Disp.TimerBarRen.appendChild(bar('Next Reindeer', [{id: 'CMTimerBarRenMinBar', color: CM.Disp.colorGray}, {id: 'CMTimerBarRenBar', color: CM.Disp.colorOrange}], 'CMTimerBarRenTime')); CM.Disp.TimerBar.appendChild(CM.Disp.TimerBarRen); - + CM.Disp.TimerBarBuff1 = document.createElement('div'); CM.Disp.TimerBarBuff1.id = 'CMTimerBarBuff1'; CM.Disp.TimerBarBuff1.style.height = '12px'; @@ -893,7 +895,7 @@ CM.Disp.CreateTimerBar = function() { CM.Disp.TimerBarBuff1.appendChild(bar('', [{id: 'CMTimerBarBuff1Bar'}], 'CMTimerBarBuff1Time')); CM.Disp.TimerBarBuff1.firstChild.firstChild.id = 'CMTimerBarBuff1Type'; CM.Disp.TimerBar.appendChild(CM.Disp.TimerBarBuff1); - + CM.Disp.TimerBarBuff2 = document.createElement('div'); CM.Disp.TimerBarBuff2.id = 'CMTimerBarBuff2'; CM.Disp.TimerBarBuff2.style.height = '12px'; @@ -902,7 +904,7 @@ CM.Disp.CreateTimerBar = function() { CM.Disp.TimerBarBuff2.appendChild(bar('', [{id: 'CMTimerBarBuff2Bar'}], 'CMTimerBarBuff2Time')); CM.Disp.TimerBarBuff2.firstChild.firstChild.id = 'CMTimerBarBuff2Type'; CM.Disp.TimerBar.appendChild(CM.Disp.TimerBarBuff2); - + l('wrapper').appendChild(CM.Disp.TimerBar); } @@ -935,7 +937,7 @@ CM.Disp.UpdateTimerBar = function() { // label width: 113, timer width: 26, div margin: 20 var maxWidth = CM.Disp.TimerBar.offsetWidth - 159; var count = 0; - + if (Game.shimmerTypes['golden'].spawned == 0 && !Game.Has('Golden switch [off]')) { CM.Disp.TimerBarGC.style.display = ''; l('CMTimerBarGCMinBar').style.width = Math.round(Math.max(0, Game.shimmerTypes['golden'].minTime - Game.shimmerTypes['golden'].time) * maxWidth / Game.shimmerTypes['golden'].maxTime) + 'px'; @@ -954,7 +956,7 @@ CM.Disp.UpdateTimerBar = function() { else { CM.Disp.TimerBarGC.style.display = 'none'; } - + if (Game.season == 'christmas' && Game.shimmerTypes['reindeer'].spawned == 0) { CM.Disp.TimerBarRen.style.display = ''; l('CMTimerBarRenMinBar').style.width = Math.round(Math.max(0, Game.shimmerTypes['reindeer'].minTime - Game.shimmerTypes['reindeer'].time) * maxWidth / Game.shimmerTypes['reindeer'].maxTime) + 'px'; @@ -965,7 +967,7 @@ CM.Disp.UpdateTimerBar = function() { else { CM.Disp.TimerBarRen.style.display = 'none'; } - + var buffCount = 0; for (var i in Game.buffs) { if (Game.buffs[i]) { @@ -994,7 +996,7 @@ CM.Disp.UpdateTimerBar = function() { CM.Disp.TimerBarBuff1.style.display = 'none'; } } - + /*if (Game.frenzy > 0) { CM.Disp.TimerBarBuff1.style.display = ''; if (Game.frenzyPower == 7) { @@ -1020,7 +1022,7 @@ CM.Disp.UpdateTimerBar = function() { else { CM.Disp.TimerBarBuff1.style.display = 'none'; } - + if (Game.clickFrenzy > 0) { CM.Disp.TimerBarBuff2.style.display = ''; if (Game.clickFrenzyPower == 777) { @@ -1038,7 +1040,7 @@ CM.Disp.UpdateTimerBar = function() { else { CM.Disp.TimerBarBuff2.style.display = 'none'; }*/ - + if (count != 0) { var height = 48 / count; CM.Disp.TimerBarGC.style.height = height + 'px'; @@ -1064,14 +1066,14 @@ CM.Disp.UpdateBotTimerBarDisplay = function() { else { // No bars l('game').style.bottom = '0px'; } - + if (CM.Config.TimerBar == 1 && CM.Config.TimerBarPos == 0) { l('sectionLeft').style.top = '48px'; } else { l('sectionLeft').style.top = ''; } - + CM.Disp.UpdateBackground(); } @@ -1107,7 +1109,7 @@ CM.Disp.CreateUpgradeBar = function() { CM.Disp.UpgradeBar.style.fontWeight = 'bold'; CM.Disp.UpgradeBar.style.display = 'none'; CM.Disp.UpgradeBar.onmouseout = function() { Game.tooltip.hide(); }; - + var placeholder = document.createElement('div'); var legend = document.createElement('div'); legend.style.minWidth = '330px'; @@ -1117,7 +1119,7 @@ CM.Disp.CreateUpgradeBar = function() { title.style.marginBottom = '4px'; title.textContent = 'Legend'; legend.appendChild(title); - + var legendLine = function(color, text) { var div = document.createElement('div'); div.style.verticalAlign = 'middle'; @@ -1131,7 +1133,7 @@ CM.Disp.CreateUpgradeBar = function() { div.appendChild(document.createTextNode(text)); return div; } - + legend.appendChild(legendLine(CM.Disp.colorBlue, 'Better than best PP building')); legend.appendChild(legendLine(CM.Disp.colorGreen, 'Same as best PP building')); legend.appendChild(legendLine(CM.Disp.colorYellow, 'Between best and worst PP buildings closer to best')); @@ -1140,9 +1142,9 @@ CM.Disp.CreateUpgradeBar = function() { legend.appendChild(legendLine(CM.Disp.colorPurple, 'Worse than worst PP building')); legend.appendChild(legendLine(CM.Disp.colorGray, 'Negative or infinity PP')); placeholder.appendChild(legend); - + CM.Disp.UpgradeBar.onmouseover = function() {Game.tooltip.draw(this, escape(placeholder.innerHTML), 'store');}; - + var upgradeNumber = function(id, color) { var span = document.createElement('span'); span.id = id; @@ -1159,7 +1161,7 @@ CM.Disp.CreateUpgradeBar = function() { CM.Disp.UpgradeBar.appendChild(upgradeNumber('CMUpgradeBarRed', CM.Disp.colorRed)); CM.Disp.UpgradeBar.appendChild(upgradeNumber('CMUpgradeBarPurple', CM.Disp.colorPurple)); CM.Disp.UpgradeBar.appendChild(upgradeNumber('CMUpgradeBarGray', CM.Disp.colorGray)); - + l('upgrades').parentNode.insertBefore(CM.Disp.UpgradeBar, l('upgrades').parentNode.childNodes[3]); } @@ -1244,7 +1246,7 @@ CM.Disp.CreateWhiteScreen = function() { CM.Disp.WhiteScreen.style.display = 'none'; CM.Disp.WhiteScreen.style.zIndex = '9999999999'; CM.Disp.WhiteScreen.style.position = 'absolute'; - + l('wrapper').appendChild(CM.Disp.WhiteScreen); } @@ -1327,7 +1329,7 @@ CM.Disp.CreateGCTimer = function() { CM.Disp.GCTimer.onclick = function () {CM.Disp.goldenShimmer.pop(); CM.Disp.GCTimer.style.display = 'none';}; CM.Disp.GCTimer.onmouseover = function() {CM.Disp.goldenShimmer.l.style.filter = 'brightness(125%) drop-shadow(0px 0px 3px rgba(255,255,255,1))'; CM.Disp.goldenShimmer.l.style.webkitFilter = 'brightness(125%) drop-shadow(0px 0px 3px rgba(255,255,255,1))';}; CM.Disp.GCTimer.onmouseout = function() {CM.Disp.goldenShimmer.l.style.filter = ''; CM.Disp.goldenShimmer.l.style.webkitFilter = '';}; - + l('game').appendChild(CM.Disp.GCTimer); } @@ -1355,7 +1357,7 @@ CM.Disp.CheckGoldenCookie = function() { CM.Disp.GCTimer.style.left = CM.Disp.goldenShimmer.l.style.left; CM.Disp.GCTimer.style.top = CM.Disp.goldenShimmer.l.style.top; } - + CM.Disp.Flash(3); CM.Disp.PlaySound(CM.Config.GCSoundURL); } @@ -1380,7 +1382,7 @@ CM.Disp.CheckSeasonPopup = function() { break; } } - + CM.Disp.Flash(3); CM.Disp.PlaySound(CM.Config.SeaSoundURL); } @@ -1393,7 +1395,7 @@ CM.Disp.UpdateTitle = function() { } else if (CM.Config.Title == 1) { var addSP = false; - + var titleGC; var titleSP; if (CM.Disp.lastGoldenCookieState) { @@ -1419,12 +1421,12 @@ CM.Disp.UpdateTitle = function() { titleSP = '[' + Math.ceil((Game.shimmerTypes['reindeer'].maxTime - Game.shimmerTypes['reindeer'].time) / Game.fps) + ']'; } } - + var str = CM.Cache.Title; if (str.charAt(0) == '[') { str = str.substring(str.lastIndexOf(']') + 1); } - + document.title = titleGC + (addSP ? titleSP : '') + ' ' + str; } else if (CM.Config.Title == 2) { @@ -1484,9 +1486,9 @@ CM.Disp.AddMenuPref = function(title) { } var frag = document.createDocumentFragment(); - + frag.appendChild(title()); - + var listing = function(config) { var div = document.createElement('div'); div.className = 'listing'; @@ -1506,7 +1508,7 @@ CM.Disp.AddMenuPref = function(title) { div.appendChild(label); return div; } - + var url = function(config) { var div = document.createElement('div'); div.className = 'listing'; @@ -1532,7 +1534,7 @@ CM.Disp.AddMenuPref = function(title) { div.appendChild(label); return div; } - + frag.appendChild(header('Bars/Colors')); frag.appendChild(listing('BotBar')); frag.appendChild(listing('TimerBar')); @@ -1556,7 +1558,7 @@ CM.Disp.AddMenuPref = function(title) { div.appendChild(label); frag.appendChild(div); } - + frag.appendChild(header('Calculation')); frag.appendChild(listing('CalcWrink')); frag.appendChild(listing('CPSMode')); @@ -1566,7 +1568,7 @@ CM.Disp.AddMenuPref = function(title) { frag.appendChild(header('Golden Cookie/Season Popup Emphasis')); frag.appendChild(listing('Flash')); - frag.appendChild(listing('Sound')); + frag.appendChild(listing('Sound')); var volConfig = 'Volume'; var volume = document.createElement('div'); volume.className = 'listing'; @@ -1593,22 +1595,22 @@ CM.Disp.AddMenuPref = function(title) { frag.appendChild(listing('GCTimer')); frag.appendChild(listing('Title')); frag.appendChild(listing('Favicon')); - + frag.appendChild(header('Tooltip')); frag.appendChild(listing('Tooltip')); frag.appendChild(listing('TooltipAmor')); frag.appendChild(listing('ToolWarnCaut')); frag.appendChild(listing('ToolWarnCautPos')); frag.appendChild(listing('ToolWrink')); - + frag.appendChild(header('Statistics')); frag.appendChild(listing('Stats')); frag.appendChild(listing('UpStats')); frag.appendChild(listing('TimeFormat')); frag.appendChild(listing('SayTime')); - + frag.appendChild(header('Other')); - frag.appendChild(listing('Scale')); + frag.appendChild(listing('Scale')); var resDef = document.createElement('div'); resDef.className = 'listing'; var resDefBut = document.createElement('a'); @@ -1617,9 +1619,9 @@ CM.Disp.AddMenuPref = function(title) { resDefBut.textContent = 'Restore Default'; resDef.appendChild(resDefBut); frag.appendChild(resDef); - + l('menu').childNodes[2].insertBefore(frag, l('menu').childNodes[2].childNodes[l('menu').childNodes[2].childNodes.length - 1]); - + CM.Disp.FormatButtonOnClickBak = l('formatButton').onclick; l('formatButton').onclick = function() {Game.Toggle('format', 'formatButton', 'Short numbers OFF', 'Short numbers ON', '1'); PlaySound('snd/tick.mp3'); CM.Disp.RefreshScale();}; } @@ -1649,12 +1651,12 @@ CM.Disp.AddMenuStats = function(title) { div.appendChild(span); return div; } - + var stats = document.createElement('div'); stats.className = 'subsection'; stats.appendChild(title()); - + var listing = function(name, text) { var div = document.createElement('div'); div.className = 'listing'; @@ -1666,7 +1668,7 @@ CM.Disp.AddMenuStats = function(title) { div.appendChild(text); return div; } - + var listingQuest = function(text, placeholder) { var frag = document.createDocumentFragment(); frag.appendChild(document.createTextNode(text + ' ')); @@ -1687,7 +1689,7 @@ CM.Disp.AddMenuStats = function(title) { frag.appendChild(span); return frag; } - + stats.appendChild(header('Lucky Cookies', 'Lucky')); if (CM.Config.StatsPref.Lucky) { var luckyColor = ((Game.cookies + CM.Disp.GetWrinkConfigBank()) < CM.Cache.Lucky) ? CM.Disp.colorRed : CM.Disp.colorGreen; @@ -1712,7 +1714,7 @@ CM.Disp.AddMenuStats = function(title) { luckyCurWrath *= 1.1; } var luckySplit = luckyRewardMax != luckyRewardMaxWrath; - + var luckyReqFrag = document.createDocumentFragment(); var luckyReqSpan = document.createElement('span'); luckyReqSpan.style.fontWeight = 'bold'; @@ -1741,7 +1743,7 @@ CM.Disp.AddMenuStats = function(title) { stats.appendChild(listing(listingQuest('\"Lucky!\" Reward (MAX) (Frenzy)' + (luckySplit ? ' (Golden / Wrath)' : ''), 'GoldCookTooltipPlaceholder'), document.createTextNode(Beautify(luckyRewardFrenzyMax) + (luckySplit ? (' / ' + Beautify(luckyRewardFrenzyMaxWrath)) : '')))); stats.appendChild(listing(listingQuest('\"Lucky!\" Reward (CUR)' + (luckySplit ? ' (Golden / Wrath)' : ''), 'GoldCookTooltipPlaceholder'), document.createTextNode(Beautify(luckyCur) + (luckySplit ? (' / ' + Beautify(luckyCurWrath)) : '')))); } - + stats.appendChild(header('Chain Cookies', 'Chain')); if (CM.Config.StatsPref.Chain) { var chainColor = ((Game.cookies + CM.Disp.GetWrinkConfigBank()) < CM.Cache.Chain) ? CM.Disp.colorRed : CM.Disp.colorGreen; @@ -1752,7 +1754,7 @@ CM.Disp.AddMenuStats = function(title) { var chainWrathTime = ((Game.cookies + CM.Disp.GetWrinkConfigBank()) < CM.Cache.ChainWrath) ? CM.Disp.FormatTime((CM.Cache.ChainWrath - (Game.cookies + CM.Disp.GetWrinkConfigBank())) / CM.Disp.GetCPS()) : ''; var chainWrathColorFrenzy = ((Game.cookies + CM.Disp.GetWrinkConfigBank()) < CM.Cache.ChainFrenzyWrath) ? CM.Disp.colorRed : CM.Disp.colorGreen; var chainWrathTimeFrenzy = ((Game.cookies + CM.Disp.GetWrinkConfigBank()) < CM.Cache.ChainFrenzyWrath) ? CM.Disp.FormatTime((CM.Cache.ChainFrenzyWrath - (Game.cookies + CM.Disp.GetWrinkConfigBank())) / CM.Disp.GetCPS()) : ''; - + var chainRewardMax = CM.Cache.ChainReward; var chainWrathRewardMax = CM.Cache.ChainWrathReward; var chainFrenzyRewardMax = CM.Cache.ChainFrenzyReward; @@ -1764,13 +1766,13 @@ CM.Disp.AddMenuStats = function(title) { chainRewardMax *= 1.1; chainFrenzyRewardMax *= 1.1; chainCur *= 1.1; - } + } if (Game.hasAura('Unholy Dominion')) { chainWrathRewardMax *= 1.1; chainFrenzyWrathRewardMax *= 1.1; chainCurWrath *= 1.1; } - + var chainReqFrag = document.createDocumentFragment(); var chainReqSpan = document.createElement('span'); chainReqSpan.style.fontWeight = 'bold'; @@ -1824,9 +1826,9 @@ CM.Disp.AddMenuStats = function(title) { stats.appendChild(listing(listingQuest('\"Chain\" Reward (MAX) (Frenzy) (Golden / Wrath)', 'GoldCookTooltipPlaceholder'), document.createTextNode(Beautify(chainFrenzyRewardMax) + ' / ' + Beautify(chainFrenzyWrathRewardMax)))); stats.appendChild(listing(listingQuest('\"Chain\" Reward (CUR) (Golden / Wrath)', 'GoldCookTooltipPlaceholder'), document.createTextNode(Beautify(chainCur) + ' / ' + Beautify(chainCurWrath)))); } - + var choEgg = (Game.HasUnlocked('Chocolate egg') && !Game.Has('Chocolate egg')); // Needs to be done for the checking below - + stats.appendChild(header('Prestige', 'Prestige')); if (CM.Config.StatsPref.Prestige) { var possiblePresMax = Math.floor(Game.HowMuchPrestige(Game.cookiesEarned + Game.cookiesReset + CM.Cache.WrinkGodBank + (choEgg ? CM.Cache.lastChoEgg : 0))); @@ -1851,9 +1853,9 @@ CM.Disp.AddMenuStats = function(title) { } stats.appendChild(listing(listingQuest('Reset Bonus Income', 'ResetTooltipPlaceholder'), resetFrag)); } - + if (Game.cpsSucked > 0) { - stats.appendChild(header('Wrinklers', 'Wrink')); + stats.appendChild(header('Wrinklers', 'Wrink')); if (CM.Config.StatsPref.Wrink) { var popAllFrag = document.createDocumentFragment(); popAllFrag.appendChild(document.createTextNode(Beautify(CM.Cache.WrinkBank) + ' ')); @@ -1865,7 +1867,7 @@ CM.Disp.AddMenuStats = function(title) { stats.appendChild(listing('Rewards of Popping', popAllFrag)); } } - + var specDisp = false; var halloCook = []; for (var i in CM.Data.HalloCookies) { @@ -1902,9 +1904,9 @@ CM.Disp.AddMenuStats = function(title) { specDisp = true; } } - + var centEgg = Game.Has('Century egg'); - + if (Game.season == 'christmas' || specDisp || choEgg || centEgg) { stats.appendChild(header('Season Specials', 'Sea')); if (CM.Config.StatsPref.Sea) { @@ -1959,10 +1961,10 @@ CM.Disp.AddMenuStats = function(title) { } if (centEgg) { stats.appendChild(listing('Century Egg Multiplier', document.createTextNode((Math.round((CM.Cache.CentEgg - 1) * 10000) / 100) + '%'))); - } + } } } - + stats.appendChild(header('Miscellaneous', 'Misc')); if (CM.Config.StatsPref.Misc) { stats.appendChild(listing('Average Cookies Per Second (Past ' + CM.Disp.times[CM.Config.AvgCPSHist] + (CM.Config.AvgCPSHist == 0 ? ' minute' : ' minutes') + ')', document.createTextNode(Beautify(CM.Cache.AvgCPS, 3)))); @@ -1980,7 +1982,7 @@ CM.Disp.AddMenu = function() { div.textContent = 'Cookie Monster Goodies'; return div; } - + if (Game.onMenu == 'prefs') { CM.Disp.AddMenuPref(title); } @@ -2011,7 +2013,7 @@ CM.Disp.CreateTooltipWarnCaut = function() { CM.Disp.TooltipWarnCaut.style.display = 'none'; CM.Disp.TooltipWarnCaut.style.left = 'auto'; CM.Disp.TooltipWarnCaut.style.bottom = 'auto'; - + var create = function(boxId, color, labelTextFront, labelTextBack, deficitId) { var box = document.createElement('div'); box.id = boxId; @@ -2119,7 +2121,7 @@ CM.Disp.Tooltip = function(type, name) { var buildPrice = CM.Sim.BuildingGetPrice(Game.Objects[name].basePrice, 0, Game.Objects[name].free, Game.Objects[name].amount); var amortizeAmount = buildPrice - Game.Objects[name].totalCookies; if (amortizeAmount > 0) { - l('tooltip').innerHTML = l('tooltip').innerHTML.split('so far').join('so far
' + Beautify(amortizeAmount) + ' ' + (Math.floor(amortizeAmount) == 1 ? 'cookie' : 'cookies') + ' left to amortize (' + CM.Disp.GetTimeColor(buildPrice, Game.Objects[name].totalCookies, (Game.Objects[name].storedTotalCps * Game.globalCpsMult)).text + ')'); + l('tooltip').innerHTML = l('tooltip').innerHTML.split('so far').join('so far
' + Beautify(amortizeAmount) + ' ' + (Math.floor(amortizeAmount) == 1 ? 'cookie' : 'cookies') + ' left to amortize (' + CM.Disp.GetTimeColor(buildPrice, Game.Objects[name].totalCookies, (Game.Objects[name].storedTotalCps * Game.globalCpsMult)).text + ')'); } } if (Game.buyMode == 1) { @@ -2153,11 +2155,11 @@ CM.Disp.Tooltip = function(type, name) { else { // Grimoire l('tooltip').innerHTML = Game.Objects['Wizard tower'].minigame.spellTooltip(name)(); } - + var area = document.createElement('div'); area.id = 'CMTooltipArea'; l('tooltip').appendChild(area); - + if (CM.Config.Tooltip == 1 && (type == 'u' || (type == 'b' && Game.buyMode == 1))) { l('tooltip').firstChild.style.paddingBottom = '4px'; var tooltip = document.createElement('div'); @@ -2165,7 +2167,7 @@ CM.Disp.Tooltip = function(type, name) { tooltip.style.padding = '4px'; tooltip.style.margin = '0px -4px'; tooltip.id = 'CMTooltipBorder'; - + var header = function(text) { var div = document.createElement('div'); div.style.fontWeight = 'bold'; @@ -2173,7 +2175,7 @@ CM.Disp.Tooltip = function(type, name) { div.textContent = text; return div; } - + tooltip.appendChild(header('Bonus Income')); var income = document.createElement('div'); income.style.marginBottom = '4px'; @@ -2189,21 +2191,21 @@ CM.Disp.Tooltip = function(type, name) { var time = document.createElement('div'); time.id = 'CMTooltipTime'; tooltip.appendChild(time); - + area.appendChild(tooltip); } - + CM.Disp.tooltipType = type; CM.Disp.tooltipName = name; CM.Disp.UpdateTooltip(); - + return l('tooltip').innerHTML; } CM.Disp.UpdateTooltip = function() { if (l('tooltipAnchor').style.display != 'none' && l('CMTooltipArea') != null) { - + if (CM.Disp.tooltipType == 'b' || CM.Disp.tooltipType == 'u') { // Error checking if (CM.Disp.tooltipType == 'u' && (typeof Game.UpgradesInStore[CM.Disp.tooltipName] === 'undefined' || typeof CM.Cache.Upgrades[Game.UpgradesInStore[CM.Disp.tooltipName].name] === 'undefined')) { @@ -2248,7 +2250,7 @@ CM.Disp.UpdateTooltip = function() { if (isFinite(increase) && increase != 0) { l('CMTooltipIncome').textContent += ' (' + (increase / 100) + '% of income)'; } - + var timeColor = CM.Disp.GetTimeColor(price, (Game.cookies + CM.Disp.GetWrinkConfigBank()), CM.Disp.GetCPS()); l('CMTooltipTime').textContent = timeColor.text; l('CMTooltipTime').className = CM.Disp.colorTextPre + timeColor.color; @@ -2300,10 +2302,10 @@ CM.Disp.UpdateTooltip = function() { var minigame = Game.Objects['Wizard tower'].minigame; var spellCost = minigame.getSpellCost(minigame.spellsById[CM.Disp.tooltipName]); - + if (CM.Config.Tooltip == 1 && spellCost <= minigame.magicM) { l('CMTooltipArea').innerHTML = ''; - + l('tooltip').firstChild.style.paddingBottom = '4px'; var tooltip = document.createElement('div'); tooltip.style.border = '1px solid'; @@ -2319,7 +2321,7 @@ CM.Disp.UpdateTooltip = function() { div.textContent = text; return div; } - + tooltip.appendChild(header('Time Left')); var time = document.createElement('div'); time.id = 'CMTooltipTime'; @@ -2327,7 +2329,7 @@ CM.Disp.UpdateTooltip = function() { var timeColor = CM.Disp.GetTimeColor(spellCost, minigame.magic, undefined, CM.Disp.CalculateGrimoireRefillTime(minigame.magic, minigame.magicM, spellCost)); time.textContent = timeColor.text; time.className = CM.Disp.colorTextPre + timeColor.color; - + if (spellCost <= minigame.magic) { tooltip.appendChild(header('Recover Time')); var recover = document.createElement('div'); @@ -2337,7 +2339,7 @@ CM.Disp.UpdateTooltip = function() { recover.textContent = recoverColor.text; recover.className = CM.Disp.colorTextPre + recoverColor.color; } - + l('CMTooltipArea').appendChild(tooltip); } } @@ -2495,7 +2497,6 @@ CM.Disp.TooltipWrinklerCache = []; for (var i in Game.wrinklers) { CM.Disp.TooltipWrinklerCache[i] = 0; } - /******** * Main * ********/ @@ -2749,7 +2750,7 @@ CM.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkB CM.ConfigPrefix = 'CMConfig'; CM.VersionMajor = '2.0042'; -CM.VersionMinor = '3'; +CM.VersionMinor = '2'; /******* * Sim * diff --git a/src/Cache.js b/src/Cache.js index adcf847..39c4ae3 100644 --- a/src/Cache.js +++ b/src/Cache.js @@ -133,14 +133,6 @@ CM.Cache.RemakePP = function() { CM.Cache.RemakeBuildingsOtherPP(100, 'Objects100'); } -CM.Cache.RemakeMultiple = function () { - for (var i in CM.Cache.Objects) { - var nextMultiple = 50 - Game.Objects[i].amount % 50; - CM.Cache.Objects[i].multiple_quantity = nextMultiple; - CM.Cache.Objects[i].multiple_price = CM.Sim.BuildingGetPrice(Game.Objects[i].basePrice, Game.Objects[i].amount, Game.Objects[i].free, nextMultiple); - } -} - CM.Cache.RemakeLucky = function() { CM.Cache.Lucky = (CM.Cache.NoGoldSwitchCookiesPS * 60 * 15) / 0.15; CM.Cache.Lucky /= CM.Sim.getCPSBuffMult(); diff --git a/src/Config.js b/src/Config.js index 0b2dcbf..7f7e59b 100644 --- a/src/Config.js +++ b/src/Config.js @@ -137,9 +137,8 @@ CM.ConfigData.SeaSoundURL = {label: 'Season Special Sound URL:', desc: 'URL of t CM.ConfigData.GCTimer = {label: ['Golden Cookie Timer OFF', 'Golden Cookie Timer ON'], desc: 'A timer on the Golden Cookie when it has been spawned', toggle: true, func: function() {CM.Disp.ToggleGCTimer();}}; CM.ConfigData.Title = {label: ['Title OFF', 'Title ON', 'Title Pinned Tab Highlight'], desc: 'Update title with Golden Cookie/Season Popup timers; pinned tab highlight only changes the title when a Golden Cookie/Season Popup spawns', toggle: true}; CM.ConfigData.Favicon = {label: ['Favicon OFF', 'Favicon ON'], desc: 'Update favicon with Golden/Wrath Cookie', toggle: true, func: function() {CM.Disp.UpdateFavicon();}}; -CM.ConfigData.Tooltip = {label: ['Tooltip Information OFF', 'Tooltip Information ON'], desc: 'Extra information in tooltip for buildings/upgrades/grimoire', toggle: true}; +CM.ConfigData.Tooltip = {label: ['Tooltip Information OFF', 'Tooltip Information ON'], desc: 'Extra information in tooltip for buildings/upgrades', toggle: true}; CM.ConfigData.TooltipAmor = {label: ['Tooltip Amortization Information OFF', 'Tooltip Amortization Information ON'], desc: 'Add amortization information to buildings tooltip', toggle: true}; -CM.ConfigData.TooltipNextMultiple = {label: ['Tooltip Next Multiple of 50 Information OFF', 'Tooltip Next Multiple of 50 Information ON'], desc: 'Add the total price necessary to reach the next multiple of 50 buildings of a kind to buildings tooltip', toggle: true}; CM.ConfigData.ToolWarnCaut = {label: ['Tooltip Warning/Caution OFF', 'Tooltip Warning/Caution ON'], desc: 'A warning/caution when buying if it will put the bank under the amount needed for max "Lucky!"/"Lucky!" (Frenzy) rewards', toggle: true, func: function() {CM.Disp.ToggleToolWarnCaut();}}; CM.ConfigData.ToolWarnCautPos = {label: ['Tooltip Warning/Caution Position (Left)', 'Tooltip Warning/Caution Position (Bottom)'], desc: 'Placement of the warning/caution boxes', toggle: false, func: function() {CM.Disp.ToggleToolWarnCautPos();}}; CM.ConfigData.ToolWrink = {label: ['Wrinkler Tooltip OFF', 'Wrinkler Tooltip ON'], desc: 'Shows the amount of cookies a wrinkler will give when popping it', toggle: true}; diff --git a/src/Disp.js b/src/Disp.js index 33a3a07..6678d10 100644 --- a/src/Disp.js +++ b/src/Disp.js @@ -34,7 +34,7 @@ CM.Disp.FormatTime = function(time, format) { } str += s; } else { - if (time > 777600000) return format ? 'Over 9000 days!' : '>9000d'; + if (time > 86400) return format ? 'Over 24 hours' : '>24h'; time = Math.ceil(time); var d = Math.floor(time / 86400); var h = Math.floor(time % 86400 / 3600); @@ -64,7 +64,7 @@ CM.Disp.GetTimeColor = function(price, bank, cps, time) { text = '00:00:00:00:00'; } else { - text = 'Done!'; + text = 'Ready'; } } else { @@ -96,7 +96,7 @@ CM.Disp.Beautify = function(num, frac) { num = Math.abs(num); negative = true; } - + for (var i = (CM.Disp.shortScale.length - 1); i >= 0; i--) { if (i < CM.Disp.metric.length && CM.Config.Scale == 1) { if (num >= Math.pow(1000, i + 2)) { @@ -114,7 +114,7 @@ CM.Disp.Beautify = function(num, frac) { if (answer == '') { answer = CM.Backup.Beautify(num, frac); } - + if (negative) { answer = '-' + answer; } @@ -179,14 +179,16 @@ CM.Disp.CreateBotBar = function() { CM.Disp.BotBar.style.borderTop = '1px solid black'; CM.Disp.BotBar.style.overflow = 'auto'; CM.Disp.BotBar.style.textShadow = '-1px 0 black, 0 1px black, 1px 0 black, 0 -1px black'; - + var table = document.createElement('table'); table.style.width = '100%'; table.style.textAlign = 'center'; table.style.whiteSpace = 'nowrap'; + table.style.tableLayout = 'fixed'; + table.style.overflow = 'hidden'; var tbody = document.createElement('tbody'); table.appendChild(tbody); - + var firstCol = function(text, color) { var td = document.createElement('td'); td.style.textAlign = 'right'; @@ -194,7 +196,7 @@ CM.Disp.CreateBotBar = function() { td.textContent = text; return td; } - + var type = document.createElement('tr'); type.style.fontWeight = 'bold'; type.appendChild(firstCol(CM.VersionMajor + '.' + CM.VersionMinor, CM.Disp.colorYellow)); @@ -208,7 +210,7 @@ CM.Disp.CreateBotBar = function() { var time = document.createElement('tr'); time.appendChild(firstCol('Time Left', CM.Disp.colorBlue)); tbody.appendChild(time); - + for (var i in Game.Objects) { var header = document.createElement('td'); header.appendChild(document.createTextNode((i.indexOf(' ') != -1 ? i.substring(0, i.indexOf(' ')) : i) + ' (')); @@ -220,11 +222,11 @@ CM.Disp.CreateBotBar = function() { bonus.appendChild(document.createElement('td')); pp.appendChild(document.createElement('td')); time.appendChild(document.createElement('td')); - + } - + CM.Disp.BotBar.appendChild(table); - + l('wrapper').appendChild(CM.Disp.BotBar); } @@ -242,7 +244,7 @@ CM.Disp.ToggleBotBar = function() { CM.Disp.UpdateBotBarOther = function() { if (CM.Config.BotBar == 1) { var count = 0; - + for (var i in CM.Cache.Objects) { count++; CM.Disp.BotBar.firstChild.firstChild.childNodes[0].childNodes[count].childNodes[1].textContent = Game.Objects[i].amount; @@ -256,7 +258,7 @@ CM.Disp.UpdateBotBarOther = function() { CM.Disp.UpdateBotBarTime = function() { if (CM.Config.BotBar == 1) { var count = 0; - + for (var i in CM.Cache.Objects) { count++; var timeColor = CM.Disp.GetTimeColor(Game.Objects[i].getPrice(), (Game.cookies + CM.Disp.GetWrinkConfigBank()), CM.Disp.GetCPS()); @@ -275,7 +277,7 @@ CM.Disp.CreateTimerBar = function() { CM.Disp.TimerBar.style.fontSize = '10px'; CM.Disp.TimerBar.style.fontWeight = 'bold'; CM.Disp.TimerBar.style.backgroundColor = 'black'; - + var bar = function(name, bars, time) { var div = document.createElement('div'); div.style.width = '100%'; @@ -286,7 +288,7 @@ CM.Disp.CreateTimerBar = function() { div.style.top = '0px'; div.style.right = '0px'; div.style.bottom = '0px'; - + var type = document.createElement('span'); type.style.display = 'inline-block'; type.style.textAlign = 'right'; @@ -295,7 +297,7 @@ CM.Disp.CreateTimerBar = function() { type.style.verticalAlign = 'text-top'; type.textContent = name; div.appendChild(type); - + for (var i = 0; i < bars.length; i++) { var colorBar = document.createElement('span'); colorBar.id = bars[i].id @@ -310,7 +312,7 @@ CM.Disp.CreateTimerBar = function() { } div.appendChild(colorBar); } - + var timer = document.createElement('span'); timer.id = time; timer.style.marginLeft = '5px'; @@ -318,7 +320,7 @@ CM.Disp.CreateTimerBar = function() { div.appendChild(timer); return div } - + CM.Disp.TimerBarGC = document.createElement('div'); CM.Disp.TimerBarGC.id = 'CMTimerBarGC'; CM.Disp.TimerBarGC.style.height = '12px'; @@ -326,7 +328,7 @@ CM.Disp.CreateTimerBar = function() { CM.Disp.TimerBarGC.style.position = 'relative'; CM.Disp.TimerBarGC.appendChild(bar('Next Cookie', [{id: 'CMTimerBarGCMinBar', color: CM.Disp.colorGray}, {id: 'CMTimerBarGCBar', color: CM.Disp.colorPurple}], 'CMTimerBarGCTime')); CM.Disp.TimerBar.appendChild(CM.Disp.TimerBarGC); - + CM.Disp.TimerBarRen = document.createElement('div'); CM.Disp.TimerBarRen.id = 'CMTimerBarRen'; CM.Disp.TimerBarRen.style.height = '12px'; @@ -334,7 +336,7 @@ CM.Disp.CreateTimerBar = function() { CM.Disp.TimerBarRen.style.position = 'relative'; CM.Disp.TimerBarRen.appendChild(bar('Next Reindeer', [{id: 'CMTimerBarRenMinBar', color: CM.Disp.colorGray}, {id: 'CMTimerBarRenBar', color: CM.Disp.colorOrange}], 'CMTimerBarRenTime')); CM.Disp.TimerBar.appendChild(CM.Disp.TimerBarRen); - + CM.Disp.TimerBarBuff1 = document.createElement('div'); CM.Disp.TimerBarBuff1.id = 'CMTimerBarBuff1'; CM.Disp.TimerBarBuff1.style.height = '12px'; @@ -343,7 +345,7 @@ CM.Disp.CreateTimerBar = function() { CM.Disp.TimerBarBuff1.appendChild(bar('', [{id: 'CMTimerBarBuff1Bar'}], 'CMTimerBarBuff1Time')); CM.Disp.TimerBarBuff1.firstChild.firstChild.id = 'CMTimerBarBuff1Type'; CM.Disp.TimerBar.appendChild(CM.Disp.TimerBarBuff1); - + CM.Disp.TimerBarBuff2 = document.createElement('div'); CM.Disp.TimerBarBuff2.id = 'CMTimerBarBuff2'; CM.Disp.TimerBarBuff2.style.height = '12px'; @@ -352,7 +354,7 @@ CM.Disp.CreateTimerBar = function() { CM.Disp.TimerBarBuff2.appendChild(bar('', [{id: 'CMTimerBarBuff2Bar'}], 'CMTimerBarBuff2Time')); CM.Disp.TimerBarBuff2.firstChild.firstChild.id = 'CMTimerBarBuff2Type'; CM.Disp.TimerBar.appendChild(CM.Disp.TimerBarBuff2); - + l('wrapper').appendChild(CM.Disp.TimerBar); } @@ -385,7 +387,7 @@ CM.Disp.UpdateTimerBar = function() { // label width: 113, timer width: 26, div margin: 20 var maxWidth = CM.Disp.TimerBar.offsetWidth - 159; var count = 0; - + if (Game.shimmerTypes['golden'].spawned == 0 && !Game.Has('Golden switch [off]')) { CM.Disp.TimerBarGC.style.display = ''; l('CMTimerBarGCMinBar').style.width = Math.round(Math.max(0, Game.shimmerTypes['golden'].minTime - Game.shimmerTypes['golden'].time) * maxWidth / Game.shimmerTypes['golden'].maxTime) + 'px'; @@ -404,7 +406,7 @@ CM.Disp.UpdateTimerBar = function() { else { CM.Disp.TimerBarGC.style.display = 'none'; } - + if (Game.season == 'christmas' && Game.shimmerTypes['reindeer'].spawned == 0) { CM.Disp.TimerBarRen.style.display = ''; l('CMTimerBarRenMinBar').style.width = Math.round(Math.max(0, Game.shimmerTypes['reindeer'].minTime - Game.shimmerTypes['reindeer'].time) * maxWidth / Game.shimmerTypes['reindeer'].maxTime) + 'px'; @@ -415,7 +417,7 @@ CM.Disp.UpdateTimerBar = function() { else { CM.Disp.TimerBarRen.style.display = 'none'; } - + var buffCount = 0; for (var i in Game.buffs) { if (Game.buffs[i]) { @@ -444,7 +446,7 @@ CM.Disp.UpdateTimerBar = function() { CM.Disp.TimerBarBuff1.style.display = 'none'; } } - + /*if (Game.frenzy > 0) { CM.Disp.TimerBarBuff1.style.display = ''; if (Game.frenzyPower == 7) { @@ -470,7 +472,7 @@ CM.Disp.UpdateTimerBar = function() { else { CM.Disp.TimerBarBuff1.style.display = 'none'; } - + if (Game.clickFrenzy > 0) { CM.Disp.TimerBarBuff2.style.display = ''; if (Game.clickFrenzyPower == 777) { @@ -488,7 +490,7 @@ CM.Disp.UpdateTimerBar = function() { else { CM.Disp.TimerBarBuff2.style.display = 'none'; }*/ - + if (count != 0) { var height = 48 / count; CM.Disp.TimerBarGC.style.height = height + 'px'; @@ -514,14 +516,14 @@ CM.Disp.UpdateBotTimerBarDisplay = function() { else { // No bars l('game').style.bottom = '0px'; } - + if (CM.Config.TimerBar == 1 && CM.Config.TimerBarPos == 0) { l('sectionLeft').style.top = '48px'; } else { l('sectionLeft').style.top = ''; } - + CM.Disp.UpdateBackground(); } @@ -557,7 +559,7 @@ CM.Disp.CreateUpgradeBar = function() { CM.Disp.UpgradeBar.style.fontWeight = 'bold'; CM.Disp.UpgradeBar.style.display = 'none'; CM.Disp.UpgradeBar.onmouseout = function() { Game.tooltip.hide(); }; - + var placeholder = document.createElement('div'); var legend = document.createElement('div'); legend.style.minWidth = '330px'; @@ -567,7 +569,7 @@ CM.Disp.CreateUpgradeBar = function() { title.style.marginBottom = '4px'; title.textContent = 'Legend'; legend.appendChild(title); - + var legendLine = function(color, text) { var div = document.createElement('div'); div.style.verticalAlign = 'middle'; @@ -581,7 +583,7 @@ CM.Disp.CreateUpgradeBar = function() { div.appendChild(document.createTextNode(text)); return div; } - + legend.appendChild(legendLine(CM.Disp.colorBlue, 'Better than best PP building')); legend.appendChild(legendLine(CM.Disp.colorGreen, 'Same as best PP building')); legend.appendChild(legendLine(CM.Disp.colorYellow, 'Between best and worst PP buildings closer to best')); @@ -590,9 +592,9 @@ CM.Disp.CreateUpgradeBar = function() { legend.appendChild(legendLine(CM.Disp.colorPurple, 'Worse than worst PP building')); legend.appendChild(legendLine(CM.Disp.colorGray, 'Negative or infinity PP')); placeholder.appendChild(legend); - + CM.Disp.UpgradeBar.onmouseover = function() {Game.tooltip.draw(this, escape(placeholder.innerHTML), 'store');}; - + var upgradeNumber = function(id, color) { var span = document.createElement('span'); span.id = id; @@ -609,7 +611,7 @@ CM.Disp.CreateUpgradeBar = function() { CM.Disp.UpgradeBar.appendChild(upgradeNumber('CMUpgradeBarRed', CM.Disp.colorRed)); CM.Disp.UpgradeBar.appendChild(upgradeNumber('CMUpgradeBarPurple', CM.Disp.colorPurple)); CM.Disp.UpgradeBar.appendChild(upgradeNumber('CMUpgradeBarGray', CM.Disp.colorGray)); - + l('upgrades').parentNode.insertBefore(CM.Disp.UpgradeBar, l('upgrades').parentNode.childNodes[3]); } @@ -694,7 +696,7 @@ CM.Disp.CreateWhiteScreen = function() { CM.Disp.WhiteScreen.style.display = 'none'; CM.Disp.WhiteScreen.style.zIndex = '9999999999'; CM.Disp.WhiteScreen.style.position = 'absolute'; - + l('wrapper').appendChild(CM.Disp.WhiteScreen); } @@ -777,7 +779,7 @@ CM.Disp.CreateGCTimer = function() { CM.Disp.GCTimer.onclick = function () {CM.Disp.goldenShimmer.pop(); CM.Disp.GCTimer.style.display = 'none';}; CM.Disp.GCTimer.onmouseover = function() {CM.Disp.goldenShimmer.l.style.filter = 'brightness(125%) drop-shadow(0px 0px 3px rgba(255,255,255,1))'; CM.Disp.goldenShimmer.l.style.webkitFilter = 'brightness(125%) drop-shadow(0px 0px 3px rgba(255,255,255,1))';}; CM.Disp.GCTimer.onmouseout = function() {CM.Disp.goldenShimmer.l.style.filter = ''; CM.Disp.goldenShimmer.l.style.webkitFilter = '';}; - + l('game').appendChild(CM.Disp.GCTimer); } @@ -805,7 +807,7 @@ CM.Disp.CheckGoldenCookie = function() { CM.Disp.GCTimer.style.left = CM.Disp.goldenShimmer.l.style.left; CM.Disp.GCTimer.style.top = CM.Disp.goldenShimmer.l.style.top; } - + CM.Disp.Flash(3); CM.Disp.PlaySound(CM.Config.GCSoundURL); } @@ -830,7 +832,7 @@ CM.Disp.CheckSeasonPopup = function() { break; } } - + CM.Disp.Flash(3); CM.Disp.PlaySound(CM.Config.SeaSoundURL); } @@ -843,7 +845,7 @@ CM.Disp.UpdateTitle = function() { } else if (CM.Config.Title == 1) { var addSP = false; - + var titleGC; var titleSP; if (CM.Disp.lastGoldenCookieState) { @@ -869,12 +871,12 @@ CM.Disp.UpdateTitle = function() { titleSP = '[' + Math.ceil((Game.shimmerTypes['reindeer'].maxTime - Game.shimmerTypes['reindeer'].time) / Game.fps) + ']'; } } - + var str = CM.Cache.Title; if (str.charAt(0) == '[') { str = str.substring(str.lastIndexOf(']') + 1); } - + document.title = titleGC + (addSP ? titleSP : '') + ' ' + str; } else if (CM.Config.Title == 2) { @@ -934,9 +936,9 @@ CM.Disp.AddMenuPref = function(title) { } var frag = document.createDocumentFragment(); - + frag.appendChild(title()); - + var listing = function(config) { var div = document.createElement('div'); div.className = 'listing'; @@ -956,7 +958,7 @@ CM.Disp.AddMenuPref = function(title) { div.appendChild(label); return div; } - + var url = function(config) { var div = document.createElement('div'); div.className = 'listing'; @@ -982,7 +984,7 @@ CM.Disp.AddMenuPref = function(title) { div.appendChild(label); return div; } - + frag.appendChild(header('Bars/Colors')); frag.appendChild(listing('BotBar')); frag.appendChild(listing('TimerBar')); @@ -1006,7 +1008,7 @@ CM.Disp.AddMenuPref = function(title) { div.appendChild(label); frag.appendChild(div); } - + frag.appendChild(header('Calculation')); frag.appendChild(listing('CalcWrink')); frag.appendChild(listing('CPSMode')); @@ -1016,7 +1018,7 @@ CM.Disp.AddMenuPref = function(title) { frag.appendChild(header('Golden Cookie/Season Popup Emphasis')); frag.appendChild(listing('Flash')); - frag.appendChild(listing('Sound')); + frag.appendChild(listing('Sound')); var volConfig = 'Volume'; var volume = document.createElement('div'); volume.className = 'listing'; @@ -1043,23 +1045,22 @@ CM.Disp.AddMenuPref = function(title) { frag.appendChild(listing('GCTimer')); frag.appendChild(listing('Title')); frag.appendChild(listing('Favicon')); - + frag.appendChild(header('Tooltip')); frag.appendChild(listing('Tooltip')); frag.appendChild(listing('TooltipAmor')); - frag.appendChild(listing('TooltipNextMultiple')); frag.appendChild(listing('ToolWarnCaut')); frag.appendChild(listing('ToolWarnCautPos')); frag.appendChild(listing('ToolWrink')); - + frag.appendChild(header('Statistics')); frag.appendChild(listing('Stats')); frag.appendChild(listing('UpStats')); frag.appendChild(listing('TimeFormat')); frag.appendChild(listing('SayTime')); - + frag.appendChild(header('Other')); - frag.appendChild(listing('Scale')); + frag.appendChild(listing('Scale')); var resDef = document.createElement('div'); resDef.className = 'listing'; var resDefBut = document.createElement('a'); @@ -1068,9 +1069,9 @@ CM.Disp.AddMenuPref = function(title) { resDefBut.textContent = 'Restore Default'; resDef.appendChild(resDefBut); frag.appendChild(resDef); - + l('menu').childNodes[2].insertBefore(frag, l('menu').childNodes[2].childNodes[l('menu').childNodes[2].childNodes.length - 1]); - + CM.Disp.FormatButtonOnClickBak = l('formatButton').onclick; l('formatButton').onclick = function() {Game.Toggle('format', 'formatButton', 'Short numbers OFF', 'Short numbers ON', '1'); PlaySound('snd/tick.mp3'); CM.Disp.RefreshScale();}; } @@ -1100,12 +1101,12 @@ CM.Disp.AddMenuStats = function(title) { div.appendChild(span); return div; } - + var stats = document.createElement('div'); stats.className = 'subsection'; stats.appendChild(title()); - + var listing = function(name, text) { var div = document.createElement('div'); div.className = 'listing'; @@ -1117,7 +1118,7 @@ CM.Disp.AddMenuStats = function(title) { div.appendChild(text); return div; } - + var listingQuest = function(text, placeholder) { var frag = document.createDocumentFragment(); frag.appendChild(document.createTextNode(text + ' ')); @@ -1138,7 +1139,7 @@ CM.Disp.AddMenuStats = function(title) { frag.appendChild(span); return frag; } - + stats.appendChild(header('Lucky Cookies', 'Lucky')); if (CM.Config.StatsPref.Lucky) { var luckyColor = ((Game.cookies + CM.Disp.GetWrinkConfigBank()) < CM.Cache.Lucky) ? CM.Disp.colorRed : CM.Disp.colorGreen; @@ -1163,7 +1164,7 @@ CM.Disp.AddMenuStats = function(title) { luckyCurWrath *= 1.1; } var luckySplit = luckyRewardMax != luckyRewardMaxWrath; - + var luckyReqFrag = document.createDocumentFragment(); var luckyReqSpan = document.createElement('span'); luckyReqSpan.style.fontWeight = 'bold'; @@ -1192,7 +1193,7 @@ CM.Disp.AddMenuStats = function(title) { stats.appendChild(listing(listingQuest('\"Lucky!\" Reward (MAX) (Frenzy)' + (luckySplit ? ' (Golden / Wrath)' : ''), 'GoldCookTooltipPlaceholder'), document.createTextNode(Beautify(luckyRewardFrenzyMax) + (luckySplit ? (' / ' + Beautify(luckyRewardFrenzyMaxWrath)) : '')))); stats.appendChild(listing(listingQuest('\"Lucky!\" Reward (CUR)' + (luckySplit ? ' (Golden / Wrath)' : ''), 'GoldCookTooltipPlaceholder'), document.createTextNode(Beautify(luckyCur) + (luckySplit ? (' / ' + Beautify(luckyCurWrath)) : '')))); } - + stats.appendChild(header('Chain Cookies', 'Chain')); if (CM.Config.StatsPref.Chain) { var chainColor = ((Game.cookies + CM.Disp.GetWrinkConfigBank()) < CM.Cache.Chain) ? CM.Disp.colorRed : CM.Disp.colorGreen; @@ -1203,7 +1204,7 @@ CM.Disp.AddMenuStats = function(title) { var chainWrathTime = ((Game.cookies + CM.Disp.GetWrinkConfigBank()) < CM.Cache.ChainWrath) ? CM.Disp.FormatTime((CM.Cache.ChainWrath - (Game.cookies + CM.Disp.GetWrinkConfigBank())) / CM.Disp.GetCPS()) : ''; var chainWrathColorFrenzy = ((Game.cookies + CM.Disp.GetWrinkConfigBank()) < CM.Cache.ChainFrenzyWrath) ? CM.Disp.colorRed : CM.Disp.colorGreen; var chainWrathTimeFrenzy = ((Game.cookies + CM.Disp.GetWrinkConfigBank()) < CM.Cache.ChainFrenzyWrath) ? CM.Disp.FormatTime((CM.Cache.ChainFrenzyWrath - (Game.cookies + CM.Disp.GetWrinkConfigBank())) / CM.Disp.GetCPS()) : ''; - + var chainRewardMax = CM.Cache.ChainReward; var chainWrathRewardMax = CM.Cache.ChainWrathReward; var chainFrenzyRewardMax = CM.Cache.ChainFrenzyReward; @@ -1215,13 +1216,13 @@ CM.Disp.AddMenuStats = function(title) { chainRewardMax *= 1.1; chainFrenzyRewardMax *= 1.1; chainCur *= 1.1; - } + } if (Game.hasAura('Unholy Dominion')) { chainWrathRewardMax *= 1.1; chainFrenzyWrathRewardMax *= 1.1; chainCurWrath *= 1.1; } - + var chainReqFrag = document.createDocumentFragment(); var chainReqSpan = document.createElement('span'); chainReqSpan.style.fontWeight = 'bold'; @@ -1275,9 +1276,9 @@ CM.Disp.AddMenuStats = function(title) { stats.appendChild(listing(listingQuest('\"Chain\" Reward (MAX) (Frenzy) (Golden / Wrath)', 'GoldCookTooltipPlaceholder'), document.createTextNode(Beautify(chainFrenzyRewardMax) + ' / ' + Beautify(chainFrenzyWrathRewardMax)))); stats.appendChild(listing(listingQuest('\"Chain\" Reward (CUR) (Golden / Wrath)', 'GoldCookTooltipPlaceholder'), document.createTextNode(Beautify(chainCur) + ' / ' + Beautify(chainCurWrath)))); } - + var choEgg = (Game.HasUnlocked('Chocolate egg') && !Game.Has('Chocolate egg')); // Needs to be done for the checking below - + stats.appendChild(header('Prestige', 'Prestige')); if (CM.Config.StatsPref.Prestige) { var possiblePresMax = Math.floor(Game.HowMuchPrestige(Game.cookiesEarned + Game.cookiesReset + CM.Cache.WrinkGodBank + (choEgg ? CM.Cache.lastChoEgg : 0))); @@ -1302,9 +1303,9 @@ CM.Disp.AddMenuStats = function(title) { } stats.appendChild(listing(listingQuest('Reset Bonus Income', 'ResetTooltipPlaceholder'), resetFrag)); } - + if (Game.cpsSucked > 0) { - stats.appendChild(header('Wrinklers', 'Wrink')); + stats.appendChild(header('Wrinklers', 'Wrink')); if (CM.Config.StatsPref.Wrink) { var popAllFrag = document.createDocumentFragment(); popAllFrag.appendChild(document.createTextNode(Beautify(CM.Cache.WrinkBank) + ' ')); @@ -1316,7 +1317,7 @@ CM.Disp.AddMenuStats = function(title) { stats.appendChild(listing('Rewards of Popping', popAllFrag)); } } - + var specDisp = false; var halloCook = []; for (var i in CM.Data.HalloCookies) { @@ -1353,9 +1354,9 @@ CM.Disp.AddMenuStats = function(title) { specDisp = true; } } - + var centEgg = Game.Has('Century egg'); - + if (Game.season == 'christmas' || specDisp || choEgg || centEgg) { stats.appendChild(header('Season Specials', 'Sea')); if (CM.Config.StatsPref.Sea) { @@ -1410,10 +1411,10 @@ CM.Disp.AddMenuStats = function(title) { } if (centEgg) { stats.appendChild(listing('Century Egg Multiplier', document.createTextNode((Math.round((CM.Cache.CentEgg - 1) * 10000) / 100) + '%'))); - } + } } } - + stats.appendChild(header('Miscellaneous', 'Misc')); if (CM.Config.StatsPref.Misc) { stats.appendChild(listing('Average Cookies Per Second (Past ' + CM.Disp.times[CM.Config.AvgCPSHist] + (CM.Config.AvgCPSHist == 0 ? ' minute' : ' minutes') + ')', document.createTextNode(Beautify(CM.Cache.AvgCPS, 3)))); @@ -1431,7 +1432,7 @@ CM.Disp.AddMenu = function() { div.textContent = 'Cookie Monster Goodies'; return div; } - + if (Game.onMenu == 'prefs') { CM.Disp.AddMenuPref(title); } @@ -1462,7 +1463,7 @@ CM.Disp.CreateTooltipWarnCaut = function() { CM.Disp.TooltipWarnCaut.style.display = 'none'; CM.Disp.TooltipWarnCaut.style.left = 'auto'; CM.Disp.TooltipWarnCaut.style.bottom = 'auto'; - + var create = function(boxId, color, labelTextFront, labelTextBack, deficitId) { var box = document.createElement('div'); box.id = boxId; @@ -1566,23 +1567,13 @@ CM.Disp.AddTooltipGrimoire = function() { CM.Disp.Tooltip = function(type, name) { if (type == 'b') { l('tooltip').innerHTML = Game.Objects[name].tooltip(); - var addedAmor = false; - if (CM.Config.TooltipAmor == 1) { var buildPrice = CM.Sim.BuildingGetPrice(Game.Objects[name].basePrice, 0, Game.Objects[name].free, Game.Objects[name].amount); var amortizeAmount = buildPrice - Game.Objects[name].totalCookies; if (amortizeAmount > 0) { - addedAmor = true; l('tooltip').innerHTML = l('tooltip').innerHTML.split('so far').join('so far
' + Beautify(amortizeAmount) + ' ' + (Math.floor(amortizeAmount) == 1 ? 'cookie' : 'cookies') + ' left to amortize (' + CM.Disp.GetTimeColor(buildPrice, Game.Objects[name].totalCookies, (Game.Objects[name].storedTotalCps * Game.globalCpsMult)).text + ')'); } } - - if (CM.Config.TooltipNextMultiple == 1) { - var marker = addedAmor ? ')' : 'so far'; - var multiple_quantity = CM.Cache.Objects[name].multiple_quantity; - l('tooltip').innerHTML = l('tooltip').innerHTML.split(marker + '').join(marker + '
' + multiple_quantity + ' ' + (multiple_quantity == 1 ? Game.Objects[name].single : Game.Objects[name].plural) + ' left to reach ' + (Game.Objects[name].amount + multiple_quantity) + ', ' + Beautify(CM.Cache.Objects[name].multiple_price, 2) + ' cookies in total (' + CM.Disp.GetTimeColor(CM.Cache.Objects[name].multiple_price, (Game.cookies + CM.Disp.GetWrinkConfigBank()), CM.Disp.GetCPS()).text + ')'); - } - if (Game.buyMode == 1) { var target = ''; var change = false; @@ -1614,11 +1605,11 @@ CM.Disp.Tooltip = function(type, name) { else { // Grimoire l('tooltip').innerHTML = Game.Objects['Wizard tower'].minigame.spellTooltip(name)(); } - + var area = document.createElement('div'); area.id = 'CMTooltipArea'; l('tooltip').appendChild(area); - + if (CM.Config.Tooltip == 1 && (type == 'u' || (type == 'b' && Game.buyMode == 1))) { l('tooltip').firstChild.style.paddingBottom = '4px'; var tooltip = document.createElement('div'); @@ -1626,7 +1617,7 @@ CM.Disp.Tooltip = function(type, name) { tooltip.style.padding = '4px'; tooltip.style.margin = '0px -4px'; tooltip.id = 'CMTooltipBorder'; - + var header = function(text) { var div = document.createElement('div'); div.style.fontWeight = 'bold'; @@ -1634,7 +1625,7 @@ CM.Disp.Tooltip = function(type, name) { div.textContent = text; return div; } - + tooltip.appendChild(header('Bonus Income')); var income = document.createElement('div'); income.style.marginBottom = '4px'; @@ -1650,21 +1641,21 @@ CM.Disp.Tooltip = function(type, name) { var time = document.createElement('div'); time.id = 'CMTooltipTime'; tooltip.appendChild(time); - + area.appendChild(tooltip); } - + CM.Disp.tooltipType = type; CM.Disp.tooltipName = name; CM.Disp.UpdateTooltip(); - + return l('tooltip').innerHTML; } CM.Disp.UpdateTooltip = function() { if (l('tooltipAnchor').style.display != 'none' && l('CMTooltipArea') != null) { - + if (CM.Disp.tooltipType == 'b' || CM.Disp.tooltipType == 'u') { // Error checking if (CM.Disp.tooltipType == 'u' && (typeof Game.UpgradesInStore[CM.Disp.tooltipName] === 'undefined' || typeof CM.Cache.Upgrades[Game.UpgradesInStore[CM.Disp.tooltipName].name] === 'undefined')) { @@ -1709,7 +1700,7 @@ CM.Disp.UpdateTooltip = function() { if (isFinite(increase) && increase != 0) { l('CMTooltipIncome').textContent += ' (' + (increase / 100) + '% of income)'; } - + var timeColor = CM.Disp.GetTimeColor(price, (Game.cookies + CM.Disp.GetWrinkConfigBank()), CM.Disp.GetCPS()); l('CMTooltipTime').textContent = timeColor.text; l('CMTooltipTime').className = CM.Disp.colorTextPre + timeColor.color; @@ -1761,10 +1752,10 @@ CM.Disp.UpdateTooltip = function() { var minigame = Game.Objects['Wizard tower'].minigame; var spellCost = minigame.getSpellCost(minigame.spellsById[CM.Disp.tooltipName]); - + if (CM.Config.Tooltip == 1 && spellCost <= minigame.magicM) { l('CMTooltipArea').innerHTML = ''; - + l('tooltip').firstChild.style.paddingBottom = '4px'; var tooltip = document.createElement('div'); tooltip.style.border = '1px solid'; @@ -1780,7 +1771,7 @@ CM.Disp.UpdateTooltip = function() { div.textContent = text; return div; } - + tooltip.appendChild(header('Time Left')); var time = document.createElement('div'); time.id = 'CMTooltipTime'; @@ -1788,7 +1779,7 @@ CM.Disp.UpdateTooltip = function() { var timeColor = CM.Disp.GetTimeColor(spellCost, minigame.magic, undefined, CM.Disp.CalculateGrimoireRefillTime(minigame.magic, minigame.magicM, spellCost)); time.textContent = timeColor.text; time.className = CM.Disp.colorTextPre + timeColor.color; - + if (spellCost <= minigame.magic) { tooltip.appendChild(header('Recover Time')); var recover = document.createElement('div'); @@ -1798,7 +1789,7 @@ CM.Disp.UpdateTooltip = function() { recover.textContent = recoverColor.text; recover.className = CM.Disp.colorTextPre + recoverColor.color; } - + l('CMTooltipArea').appendChild(tooltip); } } @@ -1956,4 +1947,3 @@ CM.Disp.TooltipWrinklerCache = []; for (var i in Game.wrinklers) { CM.Disp.TooltipWrinklerCache[i] = 0; } - diff --git a/src/Main.js b/src/Main.js index 5ab37a0..f4ba933 100644 --- a/src/Main.js +++ b/src/Main.js @@ -162,10 +162,6 @@ CM.Loop = function() { // Calculate PP CM.Cache.RemakePP(); - // Calculate total price until reaching next multiple of 50 - // for each building - CM.Cache.RemakeMultiple(); - // Update colors CM.Disp.UpdateBotBarOther(); CM.Disp.UpdateBuildings(); @@ -251,9 +247,9 @@ CM.DelayInit = function() { CM.HasReplaceNativeGrimoireLaunch = false; CM.HasReplaceNativeGrimoireDraw = false; -CM.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkBuildColor: 0, UpBarColor: 1, CalcWrink: 0, CPSMode: 1, AvgCPSHist: 0, AvgClicksHist: 0, ToolWarnCautBon: 0, Flash: 1, Sound: 1, Volume: 100, GCSoundURL: 'http://freesound.org/data/previews/66/66717_931655-lq.mp3', SeaSoundURL: 'http://www.freesound.org/data/previews/121/121099_2193266-lq.mp3', GCTimer: 1, Title: 1, Favicon: 1, Tooltip: 1, TooltipAmor: 0, TooltipNextMultiple: 0, ToolWarnCaut: 1, ToolWarnCautPos: 1, ToolWrink: 1, Stats: 1, UpStats: 1, TimeFormat: 0, SayTime: 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.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkBuildColor: 0, UpBarColor: 1, CalcWrink: 0, CPSMode: 1, AvgCPSHist: 0, AvgClicksHist: 0, ToolWarnCautBon: 0, Flash: 1, Sound: 1, Volume: 100, GCSoundURL: 'http://freesound.org/data/previews/66/66717_931655-lq.mp3', SeaSoundURL: 'http://www.freesound.org/data/previews/121/121099_2193266-lq.mp3', GCTimer: 1, Title: 1, Favicon: 1, Tooltip: 1, TooltipAmor: 0, ToolWarnCaut: 1, ToolWarnCautPos: 1, ToolWrink: 1, Stats: 1, UpStats: 1, TimeFormat: 0, SayTime: 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.0042'; -CM.VersionMinor = '3'; +CM.VersionMinor = '2'; From de0d148dd0327002811fa9c447edfd08b069a820 Mon Sep 17 00:00:00 2001 From: redthefed Date: Sat, 17 Feb 2018 21:19:07 -0600 Subject: [PATCH 06/18] changed combine.sh to reflect file order defined in combine.bat --- Combine.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Combine.sh b/Combine.sh index bddd2a2..be41216 100644 --- a/Combine.sh +++ b/Combine.sh @@ -1,2 +1,2 @@ #!/bin/sh -cat src/*.js > CookieMonster.js +cat ./src/Header.js ./src/Cache.js ./src/Config.js ./src/Data.js ./src/Disp.js ./src/Main.js ./src/Sim.js ./src/Footer.js > CookieMonster.js From e59b69e3f2cc9f1f6f4952c840f3740eed676b9f Mon Sep 17 00:00:00 2001 From: Valters Jansons Date: Sun, 25 Feb 2018 12:31:36 +0200 Subject: [PATCH 07/18] Add TLS to HTTP links Please use HTTPS wherever it is supported. It is just good practise, you know. This follows up commit 98924bc12e959581f07a1a1d48ee26a73cd03076. --- CookieMonster.js | 10 +++++----- src/Cache.js | 2 +- src/Disp.js | 6 +++--- src/Main.js | 2 +- 4 files changed, 10 insertions(+), 10 deletions(-) diff --git a/CookieMonster.js b/CookieMonster.js index 77a4beb..76f8e4a 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -25,7 +25,7 @@ CM.Sim = {}; CM.Cache.AddQueue = function() { CM.Cache.Queue = document.createElement('script'); CM.Cache.Queue.type = 'text/javascript'; - CM.Cache.Queue.setAttribute('src', 'http://aktanusa.github.io/CookieMonster/queue/queue.js'); + CM.Cache.Queue.setAttribute('src', 'https://aktanusa.github.io/CookieMonster/queue/queue.js'); document.head.appendChild(CM.Cache.Queue); } @@ -703,7 +703,7 @@ CM.Disp.GetConfigDisplay = function(config) { CM.Disp.AddJscolor = function() { CM.Disp.Jscolor = document.createElement('script'); CM.Disp.Jscolor.type = 'text/javascript'; - CM.Disp.Jscolor.setAttribute('src', 'http://aktanusa.github.io/CookieMonster/jscolor/jscolor.js'); + CM.Disp.Jscolor.setAttribute('src', 'https://aktanusa.github.io/CookieMonster/jscolor/jscolor.js'); document.head.appendChild(CM.Disp.Jscolor); } @@ -1301,10 +1301,10 @@ CM.Disp.CreateFavicon = function() { CM.Disp.UpdateFavicon = function() { if (CM.Config.Favicon == 1 && CM.Disp.lastGoldenCookieState) { if (CM.Disp.goldenShimmer.wrath) { - CM.Disp.Favicon.href = 'http://aktanusa.github.io/CookieMonster/favicon/wrathCookie.ico'; + CM.Disp.Favicon.href = 'https://aktanusa.github.io/CookieMonster/favicon/wrathCookie.ico'; } else { - CM.Disp.Favicon.href = 'http://aktanusa.github.io/CookieMonster/favicon/goldenCookie.ico'; + CM.Disp.Favicon.href = 'https://aktanusa.github.io/CookieMonster/favicon/goldenCookie.ico'; } } else { @@ -2745,7 +2745,7 @@ CM.DelayInit = function() { CM.HasReplaceNativeGrimoireLaunch = false; CM.HasReplaceNativeGrimoireDraw = false; -CM.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkBuildColor: 0, UpBarColor: 1, CalcWrink: 0, CPSMode: 1, AvgCPSHist: 0, AvgClicksHist: 0, ToolWarnCautBon: 0, Flash: 1, Sound: 1, Volume: 100, GCSoundURL: 'http://freesound.org/data/previews/66/66717_931655-lq.mp3', SeaSoundURL: 'http://www.freesound.org/data/previews/121/121099_2193266-lq.mp3', GCTimer: 1, Title: 1, Favicon: 1, Tooltip: 1, TooltipAmor: 0, ToolWarnCaut: 1, ToolWarnCautPos: 1, ToolWrink: 1, Stats: 1, UpStats: 1, TimeFormat: 0, SayTime: 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.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkBuildColor: 0, UpBarColor: 1, CalcWrink: 0, CPSMode: 1, AvgCPSHist: 0, 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, Tooltip: 1, TooltipAmor: 0, ToolWarnCaut: 1, ToolWarnCautPos: 1, ToolWrink: 1, Stats: 1, UpStats: 1, TimeFormat: 0, SayTime: 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.0042'; diff --git a/src/Cache.js b/src/Cache.js index 39c4ae3..ea3d7b0 100644 --- a/src/Cache.js +++ b/src/Cache.js @@ -5,7 +5,7 @@ CM.Cache.AddQueue = function() { CM.Cache.Queue = document.createElement('script'); CM.Cache.Queue.type = 'text/javascript'; - CM.Cache.Queue.setAttribute('src', 'http://aktanusa.github.io/CookieMonster/queue/queue.js'); + CM.Cache.Queue.setAttribute('src', 'https://aktanusa.github.io/CookieMonster/queue/queue.js'); document.head.appendChild(CM.Cache.Queue); } diff --git a/src/Disp.js b/src/Disp.js index a91aab5..f1787cd 100644 --- a/src/Disp.js +++ b/src/Disp.js @@ -153,7 +153,7 @@ CM.Disp.GetConfigDisplay = function(config) { CM.Disp.AddJscolor = function() { CM.Disp.Jscolor = document.createElement('script'); CM.Disp.Jscolor.type = 'text/javascript'; - CM.Disp.Jscolor.setAttribute('src', 'http://aktanusa.github.io/CookieMonster/jscolor/jscolor.js'); + CM.Disp.Jscolor.setAttribute('src', 'https://aktanusa.github.io/CookieMonster/jscolor/jscolor.js'); document.head.appendChild(CM.Disp.Jscolor); } @@ -751,10 +751,10 @@ CM.Disp.CreateFavicon = function() { CM.Disp.UpdateFavicon = function() { if (CM.Config.Favicon == 1 && CM.Disp.lastGoldenCookieState) { if (CM.Disp.goldenShimmer.wrath) { - CM.Disp.Favicon.href = 'http://aktanusa.github.io/CookieMonster/favicon/wrathCookie.ico'; + CM.Disp.Favicon.href = 'https://aktanusa.github.io/CookieMonster/favicon/wrathCookie.ico'; } else { - CM.Disp.Favicon.href = 'http://aktanusa.github.io/CookieMonster/favicon/goldenCookie.ico'; + CM.Disp.Favicon.href = 'https://aktanusa.github.io/CookieMonster/favicon/goldenCookie.ico'; } } else { diff --git a/src/Main.js b/src/Main.js index 335dd2b..e5efcd2 100644 --- a/src/Main.js +++ b/src/Main.js @@ -247,7 +247,7 @@ CM.DelayInit = function() { CM.HasReplaceNativeGrimoireLaunch = false; CM.HasReplaceNativeGrimoireDraw = false; -CM.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkBuildColor: 0, UpBarColor: 1, CalcWrink: 0, CPSMode: 1, AvgCPSHist: 0, AvgClicksHist: 0, ToolWarnCautBon: 0, Flash: 1, Sound: 1, Volume: 100, GCSoundURL: 'http://freesound.org/data/previews/66/66717_931655-lq.mp3', SeaSoundURL: 'http://www.freesound.org/data/previews/121/121099_2193266-lq.mp3', GCTimer: 1, Title: 1, Favicon: 1, Tooltip: 1, TooltipAmor: 0, ToolWarnCaut: 1, ToolWarnCautPos: 1, ToolWrink: 1, Stats: 1, UpStats: 1, TimeFormat: 0, SayTime: 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.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkBuildColor: 0, UpBarColor: 1, CalcWrink: 0, CPSMode: 1, AvgCPSHist: 0, 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, Tooltip: 1, TooltipAmor: 0, ToolWarnCaut: 1, ToolWarnCautPos: 1, ToolWrink: 1, Stats: 1, UpStats: 1, TimeFormat: 0, SayTime: 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.0042'; From 4ad6cc9fe047f6cbabc0936da529d3f5f201c484 Mon Sep 17 00:00:00 2001 From: Valters Jansons Date: Sun, 25 Feb 2018 12:24:31 +0200 Subject: [PATCH 08/18] Update README to use HTTPS instead of HTTP HTTPS is good to push for wherever possible, even if the Cookie Clicker site itself does not support it now. (cherry picked from commit 98924bc12e959581f07a1a1d48ee26a73cd03076) --- README.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index f1809ec..de05f72 100644 --- a/README.md +++ b/README.md @@ -54,7 +54,7 @@ Copy this code and save it as a bookmark. Paste it in the URL section. To activa ```javascript javascript: (function () { - Game.LoadMod('http://aktanusa.github.io/CookieMonster/CookieMonster.js'); + Game.LoadMod('https://aktanusa.github.io/CookieMonster/CookieMonster.js'); }()); ``` @@ -64,7 +64,7 @@ For beta, use the following instead: ```javascript javascript: (function () { - Game.LoadMod('http://aktanusa.github.io/CookieMonster/CookieMonsterBeta.js'); + Game.LoadMod('https://aktanusa.github.io/CookieMonster/CookieMonsterBeta.js'); }()); ``` @@ -84,7 +84,7 @@ If you'd rather use the addon as a script via per example *Greasemonkey* or *Tam (function() { var checkReady = setInterval(function() { if (typeof Game.ready !== 'undefined' && Game.ready) { - Game.LoadMod('http://aktanusa.github.io/CookieMonster/CookieMonster.js'); + Game.LoadMod('https://aktanusa.github.io/CookieMonster/CookieMonster.js'); clearInterval(checkReady); } }, 1000); @@ -104,7 +104,7 @@ If you are using the beta, use this instead: (function() { var checkReady = setInterval(function() { if (typeof Game.ready !== 'undefined' && Game.ready) { - Game.LoadMod('http://aktanusa.github.io/CookieMonster/CookieMonsterBeta.js'); + Game.LoadMod('https://aktanusa.github.io/CookieMonster/CookieMonsterBeta.js'); clearInterval(checkReady); } }, 1000); @@ -129,7 +129,7 @@ All suggestions are welcome, even the smallest ones. # Contributors -* **[Raving_Kumquat](http://cookieclicker.wikia.com/wiki/User:Raving_Kumquat)**: Original author +* **[Raving_Kumquat](https://cookieclicker.wikia.com/wiki/User:Raving_Kumquat)**: Original author * **[Maxime Fabre](https://github.com/Anahkiasen)**: Previous maintainer * **[Alderi Tokori](http://forum.dashnet.org/profile/Alderi)**: ROI calculations (unused now) * **[Alhifar](https://github.com/Alhifar)**: Missed Golden Cookie Stat From bd0cd9900da0e018de578137fb3e9a0ac651f4e6 Mon Sep 17 00:00:00 2001 From: redthefed Date: Wed, 28 Feb 2018 23:51:21 -0600 Subject: [PATCH 09/18] Fixed a few spelling errors and whitespace (#3) * linting, spelling errors --- CookieMonster.js | 180 +++++++++++++++++++++++------------------------ src/Cache.js | 51 +++++++------- src/Config.js | 7 +- src/Data.js | 1 - src/Header.js | 1 - src/Main.js | 53 +++++++------- src/Sim.js | 67 +++++++++--------- 7 files changed, 174 insertions(+), 186 deletions(-) diff --git a/CookieMonster.js b/CookieMonster.js index 45e22d0..f7f8270 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -17,11 +17,10 @@ CM.Data = {}; CM.Disp = {}; CM.Sim = {}; - /********* * Cache * *********/ - + CM.Cache.AddQueue = function() { CM.Cache.Queue = document.createElement('script'); CM.Cache.Queue.type = 'text/javascript'; @@ -50,10 +49,10 @@ CM.Cache.RemakeIncome = function() { // Simulate Upgrade Buys CM.Sim.BuyUpgrades(); - + // Simulate Building Buys for 10 amount CM.Sim.BuyBuildings(10, 'Objects10'); - + // Simulate Building Buys for 100 amount CM.Sim.BuyBuildings(100, 'Objects100'); } @@ -142,15 +141,15 @@ CM.Cache.RemakeBuildingsOtherPP = function(amount, target) { CM.Cache.RemakePP = function() { // Buildings for 1 amount CM.Cache.RemakeBuildingsPP(); - + // Upgrades CM.Cache.RemakeUpgradePP(); - + // Buildings for 10 amount CM.Cache.RemakeBuildingsOtherPP(10, 'Objects10'); // Buildings for 100 amount - CM.Cache.RemakeBuildingsOtherPP(100, 'Objects100'); + CM.Cache.RemakeBuildingsOtherPP(100, 'Objects100'); } CM.Cache.RemakeLucky = function() { @@ -176,11 +175,11 @@ CM.Cache.MaxChainMoni = function(digit, maxPayout) { CM.Cache.RemakeChain = function() { var maxPayout = CM.Cache.NoGoldSwitchCookiesPS * 60 * 60 * 6; maxPayout /= CM.Sim.getCPSBuffMult(); - + CM.Cache.ChainReward = CM.Cache.MaxChainMoni(7, maxPayout); - + CM.Cache.ChainWrathReward = CM.Cache.MaxChainMoni(6, maxPayout); - + if (maxPayout < CM.Cache.ChainReward) { CM.Cache.Chain = 0; } @@ -193,11 +192,11 @@ CM.Cache.RemakeChain = function() { else { CM.Cache.ChainWrath = CM.Cache.NextNumber(CM.Cache.ChainWrathReward) / 0.25; } - + CM.Cache.ChainFrenzyReward = CM.Cache.MaxChainMoni(7, maxPayout * 7); - + CM.Cache.ChainFrenzyWrathReward = CM.Cache.MaxChainMoni(6, maxPayout * 7); - + if ((maxPayout * 7) < CM.Cache.ChainFrenzyReward) { CM.Cache.ChainFrenzy = 0; } @@ -216,7 +215,7 @@ CM.Cache.RemakeSeaSpec = function() { if (Game.season == 'christmas') { var val = Game.cookiesPs * 60; if (Game.hasBuff('Elder frenzy')) val *= 0.5; // very sorry - if (Game.hasBuff('Frenzy')) val *= 0.75; // I sincerely apologize + if (Game.hasBuff('Frenzy')) val *= 0.75; // I sincerely apologize CM.Cache.SeaSpec = Math.max(25, val); if (Game.Has('Ho ho ho-flavored frosting')) CM.Cache.SeaSpec *= 2; } @@ -260,7 +259,7 @@ CM.Cache.InitCookiesDiff = function() { CM.Cache.UpdateAvgCPS = function() { var currDate = Math.floor(Date.now() / 1000); - if (CM.Cache.lastDate != currDate) { + if (CM.Cache.lastDate != currDate) { var choEggTotal = Game.cookies + CM.Cache.SellForChoEgg; if (Game.cpsSucked > 0) { choEggTotal += CM.Cache.WrinkGodBank; @@ -277,7 +276,7 @@ CM.Cache.UpdateAvgCPS = function() { CM.Cache.CookiesDiff.enqueue(bankDiffAvg); CM.Cache.WrinkDiff.enqueue(wrinkDiffAvg); CM.Cache.ChoEggDiff.enqueue(choEggDiffAvg); - CM.Cache.ClicksDiff.enqueue(clicksDiffAvg); + CM.Cache.ClicksDiff.enqueue(clicksDiffAvg); } // Assumes the queues are the same length while (CM.Cache.CookiesDiff.getLength() > 1800) { @@ -285,7 +284,7 @@ CM.Cache.UpdateAvgCPS = function() { CM.Cache.WrinkDiff.dequeue(); CM.Cache.ClicksDiff.dequeue(); } - + while (CM.Cache.ClicksDiff.getLength() > 30) { CM.Cache.ClicksDiff.dequeue(); } @@ -295,14 +294,14 @@ CM.Cache.UpdateAvgCPS = function() { CM.Cache.lastWrinkCookies = CM.Cache.WrinkBank; CM.Cache.lastChoEgg = choEggTotal; CM.Cache.lastClicks = Game.cookieClicks; - + var sortedGainBank = new Array(); var sortedGainWrink = new Array(); var sortedGainChoEgg = new Array(); - + var cpsLength = Math.min(CM.Cache.CookiesDiff.getLength(), CM.Disp.times[CM.Config.AvgCPSHist] * 60); - - // Assumes the queues are the same length + + // Assumes the queues are the same length for (var i = CM.Cache.CookiesDiff.getLength() - cpsLength; i < CM.Cache.CookiesDiff.getLength(); i++) { sortedGainBank.push(CM.Cache.CookiesDiff.get(i)); sortedGainWrink.push(CM.Cache.WrinkDiff.get(i)); @@ -312,9 +311,9 @@ CM.Cache.UpdateAvgCPS = function() { sortedGainBank.sort(function(a, b) { return a - b; }); sortedGainWrink.sort(function(a, b) { return a - b; }); sortedGainChoEgg.sort(function(a, b) { return a - b; }); - + var cut = Math.round(sortedGainBank.length / 10); - + while (cut > 0) { sortedGainBank.shift(); sortedGainBank.pop(); @@ -324,7 +323,7 @@ CM.Cache.UpdateAvgCPS = function() { sortedGainChoEgg.pop(); cut--; } - + var totalGainBank = 0; var totalGainWrink = 0; var totalGainChoEgg = 0; @@ -335,9 +334,9 @@ CM.Cache.UpdateAvgCPS = function() { totalGainChoEgg += sortedGainChoEgg[i]; } CM.Cache.AvgCPS = (totalGainBank + (CM.Config.CalcWrink ? totalGainWrink : 0)) / sortedGainBank.length; - + var choEgg = (Game.HasUnlocked('Chocolate egg') && !Game.Has('Chocolate egg')); - + if (choEgg || CM.Config.CalcWrink == 0) { CM.Cache.AvgCPSChoEgg = (totalGainBank + totalGainWrink + (choEgg ? totalGainChoEgg : 0)) / sortedGainBank.length; } @@ -389,7 +388,6 @@ CM.Cache.ClicksDiff; CM.Cache.AvgCPS = -1; CM.Cache.AvgCPSChoEgg = -1; CM.Cache.AvgClicks = -1; - /********** * Config * **********/ @@ -401,7 +399,7 @@ CM.SaveConfig = function(config) { CM.LoadConfig = function() { if (localStorage.getItem(CM.ConfigPrefix) != null) { CM.Config = JSON.parse(localStorage.getItem(CM.ConfigPrefix)); - + // Check values var mod = false; for (var i in CM.ConfigDefault) { @@ -448,8 +446,8 @@ CM.LoadConfig = function() { } } } - else { // Default values - CM.RestoreDefault(); + else { // Default values + CM.RestoreDefault(); } } @@ -539,7 +537,6 @@ CM.ConfigData.UpStats = {label: ['Statistics Update Rate (Default)', 'Statistics CM.ConfigData.TimeFormat = {label: ['Time XXd, XXh, XXm, XXs', 'Time XX:XX:XX:XX:XX'], desc: 'Change the time format', toggle: false}; CM.ConfigData.SayTime = {label: ['Format Time OFF', 'Format Time ON'], desc: 'Change how time is displayed in statistics', toggle: true, func: function() {CM.Disp.ToggleSayTime();}}; CM.ConfigData.Scale = {label: ['Game\'s Setting Scale', 'Metric', 'Short Scale', 'Scientific Notation'], desc: 'Change how long numbers are handled', toggle: false, func: function() {CM.Disp.RefreshScale();}}; - /******** * Data * ********/ @@ -547,7 +544,6 @@ CM.ConfigData.Scale = {label: ['Game\'s Setting Scale', 'Metric', 'Short Scale', CM.Data.HalloCookies = ['Skull cookies', 'Ghost cookies', 'Bat cookies', 'Slime cookies', 'Pumpkin cookies', 'Eyeball cookies', 'Spider cookies']; CM.Data.ChristCookies = ['Christmas tree biscuits', 'Snowflake biscuits', 'Snowman biscuits', 'Holly biscuits', 'Candy cane biscuits', 'Bell biscuits', 'Present biscuits']; CM.Data.ValCookies = ['Pure heart biscuits', 'Ardent heart biscuits', 'Sour heart biscuits', 'Weeping heart biscuits', 'Golden heart biscuits', 'Eternal heart biscuits']; - /******** * Disp * ********/ @@ -2500,7 +2496,7 @@ for (var i in Game.wrinklers) { /******** * Main * ********/ - + CM.ReplaceNative = function() { CM.Backup.Beautify = Beautify; Beautify = CM.Disp.Beautify; @@ -2511,7 +2507,7 @@ CM.ReplaceNative = function() { CM.Sim.DoSims = 1; CM.Sim.Date = Date.now(); } - + CM.Backup.tooltip = {}; CM.Backup.tooltip.draw = Game.tooltip.draw; eval('CM.Backup.tooltip.drawMod = ' + Game.tooltip.draw.toString().split('this').join('Game.tooltip')); @@ -2519,7 +2515,7 @@ CM.ReplaceNative = function() { CM.Backup.tooltip.drawMod(from, text, origin); CM.Disp.DrawTooltipWarnCaut(); } - + CM.Backup.tooltip.update = Game.tooltip.update; eval('CM.Backup.tooltip.updateMod = ' + Game.tooltip.update.toString().split('this.').join('Game.tooltip.')); Game.tooltip.update = function() { @@ -2527,7 +2523,7 @@ CM.ReplaceNative = function() { CM.Disp.UpdateTooltipWarnCaut(); CM.Disp.UpdateTooltipLocation(); } - + CM.Backup.UpdateSpecial = Game.UpdateSpecial; Game.UpdateSpecial = function() { if (CM.Config.TimerBar == 1 && CM.Config.TimerBarPos == 0) { @@ -2555,7 +2551,7 @@ CM.ReplaceNative = function() { CM.Disp.AddTooltipUpgrade(); Game.CalculateGains(); } - + CM.Backup.UpdateMenu = Game.UpdateMenu; Game.UpdateMenu = function() { if (typeof jscolor.picker === 'undefined' || typeof jscolor.picker.owner === 'undefined') { @@ -2563,24 +2559,24 @@ CM.ReplaceNative = function() { CM.Disp.AddMenu(); } } - + CM.Backup.sayTime = Game.sayTime; CM.Disp.sayTime = function(time, detail) { if (isNaN(time) || time <= 0) return CM.Backup.sayTime(time, detail); else return CM.Disp.FormatTime(time / Game.fps, 1); } - + CM.Backup.Loop = Game.Loop; Game.Loop = function() { CM.Backup.Loop(); CM.Loop(); } - + CM.Backup.Logic = Game.Logic; - eval('CM.Backup.LogicMod = ' + Game.Logic.toString().split('document.title').join('CM.Cache.Title')); + eval('CM.Backup.LogicMod = ' + Game.Logic.toString().split('document.title').join('CM.Cache.Title')); Game.Logic = function() { CM.Backup.LogicMod(); - + // Update Title CM.Disp.UpdateTitle(); } @@ -2626,19 +2622,19 @@ CM.Loop = function() { CM.Disp.UpdateAscendState(); } if (!Game.OnAscend && Game.AscendTimer == 0) { - if (CM.Sim.DoSims) { + if (CM.Sim.DoSims) { CM.Cache.RemakeIncome(); - + CM.Sim.NoGoldSwitchCookiesPS(); // Needed first CM.Cache.RemakeLucky(); CM.Cache.RemakeChain(); - + CM.Cache.RemakeSeaSpec(); CM.Cache.RemakeSellForChoEgg(); - + CM.Sim.DoSims = 0; } - + // Check for aura change to recalculate buildings prices var hasFierHoard = Game.hasAura('Fierce Hoarder'); if (!CM.Cache.HadFierHoard && hasFierHoard) { @@ -2649,15 +2645,15 @@ CM.Loop = function() { CM.Cache.HadFierHoard = false; CM.Cache.DoRemakeBuildPrices = 1; } - + if (CM.Cache.DoRemakeBuildPrices) { CM.Cache.RemakeBuildingsPrices(); CM.Cache.DoRemakeBuildPrices = 0; } - + // Update Wrinkler Bank CM.Cache.RemakeWrinkBank(); - + // Calculate PP CM.Cache.RemakePP(); @@ -2665,11 +2661,11 @@ CM.Loop = function() { CM.Disp.UpdateBotBarOther(); CM.Disp.UpdateBuildings(); CM.Disp.UpdateUpgrades(); - + // Redraw timers CM.Disp.UpdateBotBarTime(); CM.Disp.UpdateTimerBar(); - + // Update Tooltip CM.Disp.UpdateTooltip(); @@ -2680,10 +2676,10 @@ CM.Loop = function() { // Change menu refresh interval CM.Disp.RefreshMenu(); } - + // Check Golden Cookies CM.Disp.CheckGoldenCookie(); - + // Check Season Popup CM.Disp.CheckSeasonPopup(); @@ -2699,7 +2695,7 @@ CM.Init = function() { if (proceed) { CM.Cache.AddQueue(); CM.Disp.AddJscolor(); - + var delay = setInterval(function() { if (typeof Queue !== 'undefined' && typeof jscolor !== 'undefined') { CM.DelayInit(); @@ -2719,11 +2715,11 @@ CM.DelayInit = function() { CM.Disp.CreateFavicon(); CM.Disp.CreateGCTimer(); CM.Disp.CreateTooltip('GoldCookTooltipPlaceholder', 'Calculated with Golden Switch off', '200px'); - CM.Disp.CreateTooltip('PrestMaxTooltipPlaceholder', 'The MAX prestige is calculated with the cookies gained from popping all wrinklers with Skruuia god in Diamind slot, selling all buildings with Earth Shatterer aura, and buying Chocolate egg', '370px'); + CM.Disp.CreateTooltip('PrestMaxTooltipPlaceholder', 'The MAX prestige is calculated with the cookies gained from popping all wrinklers with Skruuia god in Diamond slot, selling all buildings with Earth Shatterer aura, and buying Chocolate egg', '370px'); CM.Disp.CreateTooltip('NextPrestTooltipPlaceholder', 'Calculated with cookies gained from wrinklers and Chocolate egg', '200px'); - CM.Disp.CreateTooltip('HeavenChipMaxTooltipPlaceholder', 'The MAX heavenly chips is calculated with the cookies gained from popping all wrinklers with Skruuia god in Diamind slot, selling all buildings with Earth Shatterer aura, and buying Chocolate egg', '390px'); + CM.Disp.CreateTooltip('HeavenChipMaxTooltipPlaceholder', 'The MAX heavenly chips is calculated with the cookies gained from popping all wrinklers with Skruuia god in Diamond slot, selling all buildings with Earth Shatterer aura, and buying Chocolate egg', '390px'); CM.Disp.CreateTooltip('ResetTooltipPlaceholder', 'The bonus income you would get from new prestige levels unlocked at 100% of its potential and from reset achievements if you have the same buildings/upgrades after reset', '370px'); - CM.Disp.CreateTooltip('ChoEggTooltipPlaceholder', 'The amount of cookies you would get from popping all wrinklers with Skruuia god in Diamind slot, selling all buildings with Earth Shatterer aura, and then buying Chocolate egg', '360px'); + CM.Disp.CreateTooltip('ChoEggTooltipPlaceholder', 'The amount of cookies you would get from popping all wrinklers with Skruuia god in Diamond slot, selling all buildings with Earth Shatterer aura, and then buying Chocolate egg', '360px'); CM.Disp.CreateTooltipWarnCaut(); CM.Disp.AddTooltipBuild(); CM.Disp.AddTooltipGrimoire(); @@ -2751,7 +2747,6 @@ CM.ConfigPrefix = 'CMConfig'; CM.VersionMajor = '2.0042'; CM.VersionMinor = '2'; - /******* * Sim * *******/ @@ -2833,8 +2828,8 @@ eval('CM.Sim.HasAchiev = ' + Game.HasAchiev.toString().split('Game').join('CM.Si eval('CM.Sim.GetHeavenlyMultiplier = ' + Game.GetHeavenlyMultiplier.toString().split('Game.Has').join('CM.Sim.Has').split('Game.hasAura').join('CM.Sim.hasAura')); CM.Sim.hasAura = function(what) { - if (Game.dragonAuras[CM.Sim.dragonAura].name == what || Game.dragonAuras[CM.Sim.dragonAura2].name == what) - return true; + if (Game.dragonAuras[CM.Sim.dragonAura].name == what || Game.dragonAuras[CM.Sim.dragonAura2].name == what) + return true; else return false; } @@ -2886,7 +2881,7 @@ CM.Sim.CopyData = function() { CM.Sim.prestige = Game.prestige; CM.Sim.dragonAura = Game.dragonAura; CM.Sim.dragonAura2 = Game.dragonAura2; - + // Buildings for (var i in Game.Objects) { var me = Game.Objects[i]; @@ -2995,7 +2990,7 @@ CM.Sim.CalculateGains = function() { if (CM.Sim.Has('Kitten specialists')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult); if (CM.Sim.Has('Kitten experts')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult); if (CM.Sim.Has('Kitten consultants')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult); - if (CM.Sim.Has('Kitten assistants to the regional manager')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult); + if (CM.Sim.Has('Kitten assistants to the regional manager')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult); if (CM.Sim.Has('Kitten angels')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.1 * milkMult); var eggMult = 1; @@ -3019,7 +3014,7 @@ CM.Sim.CalculateGains = function() { eggMult *= CM.Cache.CentEgg; } mult *= eggMult; - + if (CM.Sim.hasAura('Radiant Appetite')) mult *= 2; if (Game.hasAura('Dragon\'s Fortune')) { @@ -3030,7 +3025,7 @@ CM.Sim.CalculateGains = function() { } var rawCookiesPs = CM.Sim.cookiesPs * mult; - + for (var i in Game.CpsAchievements) { if (rawCookiesPs >= Game.CpsAchievements[i].threshold) CM.Sim.Win(Game.CpsAchievements[i].name); } @@ -3105,16 +3100,16 @@ CM.Sim.CheckOtherAchiev = function() { if (buildingsOwned >= 500) CM.Sim.Win('Architect'); if (buildingsOwned >= 1000) CM.Sim.Win('Engineer'); if (buildingsOwned >= 2000) CM.Sim.Win('Lord of Constructs'); - + if (CM.Sim.UpgradesOwned >= 20) CM.Sim.Win('Enhancer'); if (CM.Sim.UpgradesOwned >= 50) CM.Sim.Win('Augmenter'); if (CM.Sim.UpgradesOwned >= 100) CM.Sim.Win('Upgrader'); if (CM.Sim.UpgradesOwned >= 200) CM.Sim.Win('Lord of Progress'); - + if (buildingsOwned >= 3000 && CM.Sim.UpgradesOwned >= 300) CM.Sim.Win('Polymath'); - + if (CM.Sim.Objects['Cursor'].amount + CM.Sim.Objects['Grandma'].amount >= 777) CM.Sim.Win('The elder scrolls'); - + var hasAllHalloCook = true; for (var i in CM.Data.HalloCookies) { if (!CM.Sim.Has(CM.Data.HalloCookies[i])) hasAllHalloCook = false; @@ -3128,13 +3123,13 @@ CM.Sim.CheckOtherAchiev = function() { if (hasAllChristCook) CM.Sim.Win('Let it snow'); } -CM.Sim.BuyBuildings = function(amount, target) { +CM.Sim.BuyBuildings = function(amount, target) { CM.Cache[target] = []; for (var i in Game.Objects) { CM.Sim.CopyData(); var me = CM.Sim.Objects[i]; me.amount += amount; - + if (i == 'Cursor') { if (me.amount >= 1) CM.Sim.Win('Click'); if (me.amount >= 2) CM.Sim.Win('Double-click'); @@ -3147,21 +3142,21 @@ CM.Sim.BuyBuildings = function(amount, target) { } else { for (var j in Game.Objects[me.name].tieredAchievs) { - if (me.amount >= Game.Tiers[Game.Objects[me.name].tieredAchievs[j].tier].achievUnlock) + if (me.amount >= Game.Tiers[Game.Objects[me.name].tieredAchievs[j].tier].achievUnlock) CM.Sim.Win(Game.Objects[me.name].tieredAchievs[j].name); } } - + var lastAchievementsOwned = CM.Sim.AchievementsOwned; - + CM.Sim.CalculateGains(); - + CM.Sim.CheckOtherAchiev(); - + if (lastAchievementsOwned != CM.Sim.AchievementsOwned) { CM.Sim.CalculateGains(); } - + CM.Cache[target][i] = {}; CM.Cache[target][i].bonus = CM.Sim.cookiesPs - Game.cookiesPs; if (amount != 1) { @@ -3193,17 +3188,17 @@ CM.Sim.BuyUpgrades = function() { else if (i == 'Heavenly key') { CM.Sim.Win('Wholesome'); } - + var lastAchievementsOwned = CM.Sim.AchievementsOwned; - + CM.Sim.CalculateGains(); - + CM.Sim.CheckOtherAchiev(); - + if (lastAchievementsOwned != CM.Sim.AchievementsOwned) { CM.Sim.CalculateGains(); } - + CM.Cache.Upgrades[i] = {}; CM.Cache.Upgrades[i].bonus = CM.Sim.cookiesPs - Game.cookiesPs; } @@ -3222,12 +3217,12 @@ CM.Sim.NoGoldSwitchCookiesPS = function() { CM.Sim.ResetBonus = function(possiblePresMax) { var lastAchievementsOwned = -1; - + // Calculate CPS with all Heavenly upgrades var curCPS = Game.cookiesPs; - + CM.Sim.CopyData(); - + if (CM.Sim.Upgrades['Heavenly key'].bought == 0) { CM.Sim.Upgrades['Heavenly chip secret'].bought = 1; CM.Sim.Upgrades['Heavenly cookie stand'].bought = 1; @@ -3238,10 +3233,10 @@ CM.Sim.ResetBonus = function(possiblePresMax) { CM.Sim.CalculateGains(); curCPS = CM.Sim.cookiesPs; - + CM.Sim.CopyData(); } - + if (Game.cookiesEarned >= 1000000) CM.Sim.Win('Sacrifice'); if (Game.cookiesEarned >= 1000000000) CM.Sim.Win('Oblivion'); if (Game.cookiesEarned >= 1000000000000) CM.Sim.Win('From scratch'); @@ -3252,28 +3247,27 @@ CM.Sim.ResetBonus = function(possiblePresMax) { if (Game.cookiesEarned >= 1000000000000000000000000000) CM.Sim.Win('Obliterate'); if (Game.cookiesEarned >= 1000000000000000000000000000000) CM.Sim.Win('Negative void'); if (Game.cookiesEarned >= 1000000000000000000000000000000000) CM.Sim.Win('To crumbs, you say?'); - + CM.Sim.Upgrades['Heavenly chip secret'].bought = 1; CM.Sim.Upgrades['Heavenly cookie stand'].bought = 1; CM.Sim.Upgrades['Heavenly bakery'].bought = 1; CM.Sim.Upgrades['Heavenly confectionery'].bought = 1; CM.Sim.Upgrades['Heavenly key'].bought = 1; - + CM.Sim.prestige = possiblePresMax; - + lastAchievementsOwned = CM.Sim.AchievementsOwned; CM.Sim.CalculateGains(); - + CM.Sim.CheckOtherAchiev(); - + if (lastAchievementsOwned != CM.Sim.AchievementsOwned) { CM.Sim.CalculateGains(); } return (CM.Sim.cookiesPs - curCPS); } - /********** * Footer * **********/ diff --git a/src/Cache.js b/src/Cache.js index 39c4ae3..568d3cd 100644 --- a/src/Cache.js +++ b/src/Cache.js @@ -1,7 +1,7 @@ /********* * Cache * *********/ - + CM.Cache.AddQueue = function() { CM.Cache.Queue = document.createElement('script'); CM.Cache.Queue.type = 'text/javascript'; @@ -30,10 +30,10 @@ CM.Cache.RemakeIncome = function() { // Simulate Upgrade Buys CM.Sim.BuyUpgrades(); - + // Simulate Building Buys for 10 amount CM.Sim.BuyBuildings(10, 'Objects10'); - + // Simulate Building Buys for 100 amount CM.Sim.BuyBuildings(100, 'Objects100'); } @@ -122,15 +122,15 @@ CM.Cache.RemakeBuildingsOtherPP = function(amount, target) { CM.Cache.RemakePP = function() { // Buildings for 1 amount CM.Cache.RemakeBuildingsPP(); - + // Upgrades CM.Cache.RemakeUpgradePP(); - + // Buildings for 10 amount CM.Cache.RemakeBuildingsOtherPP(10, 'Objects10'); // Buildings for 100 amount - CM.Cache.RemakeBuildingsOtherPP(100, 'Objects100'); + CM.Cache.RemakeBuildingsOtherPP(100, 'Objects100'); } CM.Cache.RemakeLucky = function() { @@ -156,11 +156,11 @@ CM.Cache.MaxChainMoni = function(digit, maxPayout) { CM.Cache.RemakeChain = function() { var maxPayout = CM.Cache.NoGoldSwitchCookiesPS * 60 * 60 * 6; maxPayout /= CM.Sim.getCPSBuffMult(); - + CM.Cache.ChainReward = CM.Cache.MaxChainMoni(7, maxPayout); - + CM.Cache.ChainWrathReward = CM.Cache.MaxChainMoni(6, maxPayout); - + if (maxPayout < CM.Cache.ChainReward) { CM.Cache.Chain = 0; } @@ -173,11 +173,11 @@ CM.Cache.RemakeChain = function() { else { CM.Cache.ChainWrath = CM.Cache.NextNumber(CM.Cache.ChainWrathReward) / 0.25; } - + CM.Cache.ChainFrenzyReward = CM.Cache.MaxChainMoni(7, maxPayout * 7); - + CM.Cache.ChainFrenzyWrathReward = CM.Cache.MaxChainMoni(6, maxPayout * 7); - + if ((maxPayout * 7) < CM.Cache.ChainFrenzyReward) { CM.Cache.ChainFrenzy = 0; } @@ -196,7 +196,7 @@ CM.Cache.RemakeSeaSpec = function() { if (Game.season == 'christmas') { var val = Game.cookiesPs * 60; if (Game.hasBuff('Elder frenzy')) val *= 0.5; // very sorry - if (Game.hasBuff('Frenzy')) val *= 0.75; // I sincerely apologize + if (Game.hasBuff('Frenzy')) val *= 0.75; // I sincerely apologize CM.Cache.SeaSpec = Math.max(25, val); if (Game.Has('Ho ho ho-flavored frosting')) CM.Cache.SeaSpec *= 2; } @@ -240,7 +240,7 @@ CM.Cache.InitCookiesDiff = function() { CM.Cache.UpdateAvgCPS = function() { var currDate = Math.floor(Date.now() / 1000); - if (CM.Cache.lastDate != currDate) { + if (CM.Cache.lastDate != currDate) { var choEggTotal = Game.cookies + CM.Cache.SellForChoEgg; if (Game.cpsSucked > 0) { choEggTotal += CM.Cache.WrinkGodBank; @@ -257,7 +257,7 @@ CM.Cache.UpdateAvgCPS = function() { CM.Cache.CookiesDiff.enqueue(bankDiffAvg); CM.Cache.WrinkDiff.enqueue(wrinkDiffAvg); CM.Cache.ChoEggDiff.enqueue(choEggDiffAvg); - CM.Cache.ClicksDiff.enqueue(clicksDiffAvg); + CM.Cache.ClicksDiff.enqueue(clicksDiffAvg); } // Assumes the queues are the same length while (CM.Cache.CookiesDiff.getLength() > 1800) { @@ -265,7 +265,7 @@ CM.Cache.UpdateAvgCPS = function() { CM.Cache.WrinkDiff.dequeue(); CM.Cache.ClicksDiff.dequeue(); } - + while (CM.Cache.ClicksDiff.getLength() > 30) { CM.Cache.ClicksDiff.dequeue(); } @@ -275,14 +275,14 @@ CM.Cache.UpdateAvgCPS = function() { CM.Cache.lastWrinkCookies = CM.Cache.WrinkBank; CM.Cache.lastChoEgg = choEggTotal; CM.Cache.lastClicks = Game.cookieClicks; - + var sortedGainBank = new Array(); var sortedGainWrink = new Array(); var sortedGainChoEgg = new Array(); - + var cpsLength = Math.min(CM.Cache.CookiesDiff.getLength(), CM.Disp.times[CM.Config.AvgCPSHist] * 60); - - // Assumes the queues are the same length + + // Assumes the queues are the same length for (var i = CM.Cache.CookiesDiff.getLength() - cpsLength; i < CM.Cache.CookiesDiff.getLength(); i++) { sortedGainBank.push(CM.Cache.CookiesDiff.get(i)); sortedGainWrink.push(CM.Cache.WrinkDiff.get(i)); @@ -292,9 +292,9 @@ CM.Cache.UpdateAvgCPS = function() { sortedGainBank.sort(function(a, b) { return a - b; }); sortedGainWrink.sort(function(a, b) { return a - b; }); sortedGainChoEgg.sort(function(a, b) { return a - b; }); - + var cut = Math.round(sortedGainBank.length / 10); - + while (cut > 0) { sortedGainBank.shift(); sortedGainBank.pop(); @@ -304,7 +304,7 @@ CM.Cache.UpdateAvgCPS = function() { sortedGainChoEgg.pop(); cut--; } - + var totalGainBank = 0; var totalGainWrink = 0; var totalGainChoEgg = 0; @@ -315,9 +315,9 @@ CM.Cache.UpdateAvgCPS = function() { totalGainChoEgg += sortedGainChoEgg[i]; } CM.Cache.AvgCPS = (totalGainBank + (CM.Config.CalcWrink ? totalGainWrink : 0)) / sortedGainBank.length; - + var choEgg = (Game.HasUnlocked('Chocolate egg') && !Game.Has('Chocolate egg')); - + if (choEgg || CM.Config.CalcWrink == 0) { CM.Cache.AvgCPSChoEgg = (totalGainBank + totalGainWrink + (choEgg ? totalGainChoEgg : 0)) / sortedGainBank.length; } @@ -369,4 +369,3 @@ CM.Cache.ClicksDiff; CM.Cache.AvgCPS = -1; CM.Cache.AvgCPSChoEgg = -1; CM.Cache.AvgClicks = -1; - diff --git a/src/Config.js b/src/Config.js index 7f7e59b..bb69de6 100644 --- a/src/Config.js +++ b/src/Config.js @@ -9,7 +9,7 @@ CM.SaveConfig = function(config) { CM.LoadConfig = function() { if (localStorage.getItem(CM.ConfigPrefix) != null) { CM.Config = JSON.parse(localStorage.getItem(CM.ConfigPrefix)); - + // Check values var mod = false; for (var i in CM.ConfigDefault) { @@ -56,8 +56,8 @@ CM.LoadConfig = function() { } } } - else { // Default values - CM.RestoreDefault(); + else { // Default values + CM.RestoreDefault(); } } @@ -147,4 +147,3 @@ CM.ConfigData.UpStats = {label: ['Statistics Update Rate (Default)', 'Statistics CM.ConfigData.TimeFormat = {label: ['Time XXd, XXh, XXm, XXs', 'Time XX:XX:XX:XX:XX'], desc: 'Change the time format', toggle: false}; CM.ConfigData.SayTime = {label: ['Format Time OFF', 'Format Time ON'], desc: 'Change how time is displayed in statistics', toggle: true, func: function() {CM.Disp.ToggleSayTime();}}; CM.ConfigData.Scale = {label: ['Game\'s Setting Scale', 'Metric', 'Short Scale', 'Scientific Notation'], desc: 'Change how long numbers are handled', toggle: false, func: function() {CM.Disp.RefreshScale();}}; - diff --git a/src/Data.js b/src/Data.js index 84571d8..4779b64 100644 --- a/src/Data.js +++ b/src/Data.js @@ -5,4 +5,3 @@ CM.Data.HalloCookies = ['Skull cookies', 'Ghost cookies', 'Bat cookies', 'Slime cookies', 'Pumpkin cookies', 'Eyeball cookies', 'Spider cookies']; CM.Data.ChristCookies = ['Christmas tree biscuits', 'Snowflake biscuits', 'Snowman biscuits', 'Holly biscuits', 'Candy cane biscuits', 'Bell biscuits', 'Present biscuits']; CM.Data.ValCookies = ['Pure heart biscuits', 'Ardent heart biscuits', 'Sour heart biscuits', 'Weeping heart biscuits', 'Golden heart biscuits', 'Eternal heart biscuits']; - diff --git a/src/Header.js b/src/Header.js index 7e91767..8f6f94a 100644 --- a/src/Header.js +++ b/src/Header.js @@ -17,4 +17,3 @@ CM.Data = {}; CM.Disp = {}; CM.Sim = {}; - diff --git a/src/Main.js b/src/Main.js index f4ba933..6042c93 100644 --- a/src/Main.js +++ b/src/Main.js @@ -1,7 +1,7 @@ /******** * Main * ********/ - + CM.ReplaceNative = function() { CM.Backup.Beautify = Beautify; Beautify = CM.Disp.Beautify; @@ -12,7 +12,7 @@ CM.ReplaceNative = function() { CM.Sim.DoSims = 1; CM.Sim.Date = Date.now(); } - + CM.Backup.tooltip = {}; CM.Backup.tooltip.draw = Game.tooltip.draw; eval('CM.Backup.tooltip.drawMod = ' + Game.tooltip.draw.toString().split('this').join('Game.tooltip')); @@ -20,7 +20,7 @@ CM.ReplaceNative = function() { CM.Backup.tooltip.drawMod(from, text, origin); CM.Disp.DrawTooltipWarnCaut(); } - + CM.Backup.tooltip.update = Game.tooltip.update; eval('CM.Backup.tooltip.updateMod = ' + Game.tooltip.update.toString().split('this.').join('Game.tooltip.')); Game.tooltip.update = function() { @@ -28,7 +28,7 @@ CM.ReplaceNative = function() { CM.Disp.UpdateTooltipWarnCaut(); CM.Disp.UpdateTooltipLocation(); } - + CM.Backup.UpdateSpecial = Game.UpdateSpecial; Game.UpdateSpecial = function() { if (CM.Config.TimerBar == 1 && CM.Config.TimerBarPos == 0) { @@ -56,7 +56,7 @@ CM.ReplaceNative = function() { CM.Disp.AddTooltipUpgrade(); Game.CalculateGains(); } - + CM.Backup.UpdateMenu = Game.UpdateMenu; Game.UpdateMenu = function() { if (typeof jscolor.picker === 'undefined' || typeof jscolor.picker.owner === 'undefined') { @@ -64,24 +64,24 @@ CM.ReplaceNative = function() { CM.Disp.AddMenu(); } } - + CM.Backup.sayTime = Game.sayTime; CM.Disp.sayTime = function(time, detail) { if (isNaN(time) || time <= 0) return CM.Backup.sayTime(time, detail); else return CM.Disp.FormatTime(time / Game.fps, 1); } - + CM.Backup.Loop = Game.Loop; Game.Loop = function() { CM.Backup.Loop(); CM.Loop(); } - + CM.Backup.Logic = Game.Logic; - eval('CM.Backup.LogicMod = ' + Game.Logic.toString().split('document.title').join('CM.Cache.Title')); + eval('CM.Backup.LogicMod = ' + Game.Logic.toString().split('document.title').join('CM.Cache.Title')); Game.Logic = function() { CM.Backup.LogicMod(); - + // Update Title CM.Disp.UpdateTitle(); } @@ -127,19 +127,19 @@ CM.Loop = function() { CM.Disp.UpdateAscendState(); } if (!Game.OnAscend && Game.AscendTimer == 0) { - if (CM.Sim.DoSims) { + if (CM.Sim.DoSims) { CM.Cache.RemakeIncome(); - + CM.Sim.NoGoldSwitchCookiesPS(); // Needed first CM.Cache.RemakeLucky(); CM.Cache.RemakeChain(); - + CM.Cache.RemakeSeaSpec(); CM.Cache.RemakeSellForChoEgg(); - + CM.Sim.DoSims = 0; } - + // Check for aura change to recalculate buildings prices var hasFierHoard = Game.hasAura('Fierce Hoarder'); if (!CM.Cache.HadFierHoard && hasFierHoard) { @@ -150,15 +150,15 @@ CM.Loop = function() { CM.Cache.HadFierHoard = false; CM.Cache.DoRemakeBuildPrices = 1; } - + if (CM.Cache.DoRemakeBuildPrices) { CM.Cache.RemakeBuildingsPrices(); CM.Cache.DoRemakeBuildPrices = 0; } - + // Update Wrinkler Bank CM.Cache.RemakeWrinkBank(); - + // Calculate PP CM.Cache.RemakePP(); @@ -166,11 +166,11 @@ CM.Loop = function() { CM.Disp.UpdateBotBarOther(); CM.Disp.UpdateBuildings(); CM.Disp.UpdateUpgrades(); - + // Redraw timers CM.Disp.UpdateBotBarTime(); CM.Disp.UpdateTimerBar(); - + // Update Tooltip CM.Disp.UpdateTooltip(); @@ -181,10 +181,10 @@ CM.Loop = function() { // Change menu refresh interval CM.Disp.RefreshMenu(); } - + // Check Golden Cookies CM.Disp.CheckGoldenCookie(); - + // Check Season Popup CM.Disp.CheckSeasonPopup(); @@ -200,7 +200,7 @@ CM.Init = function() { if (proceed) { CM.Cache.AddQueue(); CM.Disp.AddJscolor(); - + var delay = setInterval(function() { if (typeof Queue !== 'undefined' && typeof jscolor !== 'undefined') { CM.DelayInit(); @@ -220,11 +220,11 @@ CM.DelayInit = function() { CM.Disp.CreateFavicon(); CM.Disp.CreateGCTimer(); CM.Disp.CreateTooltip('GoldCookTooltipPlaceholder', 'Calculated with Golden Switch off', '200px'); - CM.Disp.CreateTooltip('PrestMaxTooltipPlaceholder', 'The MAX prestige is calculated with the cookies gained from popping all wrinklers with Skruuia god in Diamind slot, selling all buildings with Earth Shatterer aura, and buying Chocolate egg', '370px'); + CM.Disp.CreateTooltip('PrestMaxTooltipPlaceholder', 'The MAX prestige is calculated with the cookies gained from popping all wrinklers with Skruuia god in Diamond slot, selling all buildings with Earth Shatterer aura, and buying Chocolate egg', '370px'); CM.Disp.CreateTooltip('NextPrestTooltipPlaceholder', 'Calculated with cookies gained from wrinklers and Chocolate egg', '200px'); - CM.Disp.CreateTooltip('HeavenChipMaxTooltipPlaceholder', 'The MAX heavenly chips is calculated with the cookies gained from popping all wrinklers with Skruuia god in Diamind slot, selling all buildings with Earth Shatterer aura, and buying Chocolate egg', '390px'); + CM.Disp.CreateTooltip('HeavenChipMaxTooltipPlaceholder', 'The MAX heavenly chips is calculated with the cookies gained from popping all wrinklers with Skruuia god in Diamond slot, selling all buildings with Earth Shatterer aura, and buying Chocolate egg', '390px'); CM.Disp.CreateTooltip('ResetTooltipPlaceholder', 'The bonus income you would get from new prestige levels unlocked at 100% of its potential and from reset achievements if you have the same buildings/upgrades after reset', '370px'); - CM.Disp.CreateTooltip('ChoEggTooltipPlaceholder', 'The amount of cookies you would get from popping all wrinklers with Skruuia god in Diamind slot, selling all buildings with Earth Shatterer aura, and then buying Chocolate egg', '360px'); + CM.Disp.CreateTooltip('ChoEggTooltipPlaceholder', 'The amount of cookies you would get from popping all wrinklers with Skruuia god in Diamond slot, selling all buildings with Earth Shatterer aura, and then buying Chocolate egg', '360px'); CM.Disp.CreateTooltipWarnCaut(); CM.Disp.AddTooltipBuild(); CM.Disp.AddTooltipGrimoire(); @@ -252,4 +252,3 @@ CM.ConfigPrefix = 'CMConfig'; CM.VersionMajor = '2.0042'; CM.VersionMinor = '2'; - diff --git a/src/Sim.js b/src/Sim.js index 8c8ef44..5f09eda 100644 --- a/src/Sim.js +++ b/src/Sim.js @@ -79,8 +79,8 @@ eval('CM.Sim.HasAchiev = ' + Game.HasAchiev.toString().split('Game').join('CM.Si eval('CM.Sim.GetHeavenlyMultiplier = ' + Game.GetHeavenlyMultiplier.toString().split('Game.Has').join('CM.Sim.Has').split('Game.hasAura').join('CM.Sim.hasAura')); CM.Sim.hasAura = function(what) { - if (Game.dragonAuras[CM.Sim.dragonAura].name == what || Game.dragonAuras[CM.Sim.dragonAura2].name == what) - return true; + if (Game.dragonAuras[CM.Sim.dragonAura].name == what || Game.dragonAuras[CM.Sim.dragonAura2].name == what) + return true; else return false; } @@ -132,7 +132,7 @@ CM.Sim.CopyData = function() { CM.Sim.prestige = Game.prestige; CM.Sim.dragonAura = Game.dragonAura; CM.Sim.dragonAura2 = Game.dragonAura2; - + // Buildings for (var i in Game.Objects) { var me = Game.Objects[i]; @@ -241,7 +241,7 @@ CM.Sim.CalculateGains = function() { if (CM.Sim.Has('Kitten specialists')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult); if (CM.Sim.Has('Kitten experts')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult); if (CM.Sim.Has('Kitten consultants')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult); - if (CM.Sim.Has('Kitten assistants to the regional manager')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult); + if (CM.Sim.Has('Kitten assistants to the regional manager')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult); if (CM.Sim.Has('Kitten angels')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.1 * milkMult); var eggMult = 1; @@ -265,7 +265,7 @@ CM.Sim.CalculateGains = function() { eggMult *= CM.Cache.CentEgg; } mult *= eggMult; - + if (CM.Sim.hasAura('Radiant Appetite')) mult *= 2; if (Game.hasAura('Dragon\'s Fortune')) { @@ -276,7 +276,7 @@ CM.Sim.CalculateGains = function() { } var rawCookiesPs = CM.Sim.cookiesPs * mult; - + for (var i in Game.CpsAchievements) { if (rawCookiesPs >= Game.CpsAchievements[i].threshold) CM.Sim.Win(Game.CpsAchievements[i].name); } @@ -351,16 +351,16 @@ CM.Sim.CheckOtherAchiev = function() { if (buildingsOwned >= 500) CM.Sim.Win('Architect'); if (buildingsOwned >= 1000) CM.Sim.Win('Engineer'); if (buildingsOwned >= 2000) CM.Sim.Win('Lord of Constructs'); - + if (CM.Sim.UpgradesOwned >= 20) CM.Sim.Win('Enhancer'); if (CM.Sim.UpgradesOwned >= 50) CM.Sim.Win('Augmenter'); if (CM.Sim.UpgradesOwned >= 100) CM.Sim.Win('Upgrader'); if (CM.Sim.UpgradesOwned >= 200) CM.Sim.Win('Lord of Progress'); - + if (buildingsOwned >= 3000 && CM.Sim.UpgradesOwned >= 300) CM.Sim.Win('Polymath'); - + if (CM.Sim.Objects['Cursor'].amount + CM.Sim.Objects['Grandma'].amount >= 777) CM.Sim.Win('The elder scrolls'); - + var hasAllHalloCook = true; for (var i in CM.Data.HalloCookies) { if (!CM.Sim.Has(CM.Data.HalloCookies[i])) hasAllHalloCook = false; @@ -374,13 +374,13 @@ CM.Sim.CheckOtherAchiev = function() { if (hasAllChristCook) CM.Sim.Win('Let it snow'); } -CM.Sim.BuyBuildings = function(amount, target) { +CM.Sim.BuyBuildings = function(amount, target) { CM.Cache[target] = []; for (var i in Game.Objects) { CM.Sim.CopyData(); var me = CM.Sim.Objects[i]; me.amount += amount; - + if (i == 'Cursor') { if (me.amount >= 1) CM.Sim.Win('Click'); if (me.amount >= 2) CM.Sim.Win('Double-click'); @@ -393,21 +393,21 @@ CM.Sim.BuyBuildings = function(amount, target) { } else { for (var j in Game.Objects[me.name].tieredAchievs) { - if (me.amount >= Game.Tiers[Game.Objects[me.name].tieredAchievs[j].tier].achievUnlock) + if (me.amount >= Game.Tiers[Game.Objects[me.name].tieredAchievs[j].tier].achievUnlock) CM.Sim.Win(Game.Objects[me.name].tieredAchievs[j].name); } } - + var lastAchievementsOwned = CM.Sim.AchievementsOwned; - + CM.Sim.CalculateGains(); - + CM.Sim.CheckOtherAchiev(); - + if (lastAchievementsOwned != CM.Sim.AchievementsOwned) { CM.Sim.CalculateGains(); } - + CM.Cache[target][i] = {}; CM.Cache[target][i].bonus = CM.Sim.cookiesPs - Game.cookiesPs; if (amount != 1) { @@ -439,17 +439,17 @@ CM.Sim.BuyUpgrades = function() { else if (i == 'Heavenly key') { CM.Sim.Win('Wholesome'); } - + var lastAchievementsOwned = CM.Sim.AchievementsOwned; - + CM.Sim.CalculateGains(); - + CM.Sim.CheckOtherAchiev(); - + if (lastAchievementsOwned != CM.Sim.AchievementsOwned) { CM.Sim.CalculateGains(); } - + CM.Cache.Upgrades[i] = {}; CM.Cache.Upgrades[i].bonus = CM.Sim.cookiesPs - Game.cookiesPs; } @@ -468,12 +468,12 @@ CM.Sim.NoGoldSwitchCookiesPS = function() { CM.Sim.ResetBonus = function(possiblePresMax) { var lastAchievementsOwned = -1; - + // Calculate CPS with all Heavenly upgrades var curCPS = Game.cookiesPs; - + CM.Sim.CopyData(); - + if (CM.Sim.Upgrades['Heavenly key'].bought == 0) { CM.Sim.Upgrades['Heavenly chip secret'].bought = 1; CM.Sim.Upgrades['Heavenly cookie stand'].bought = 1; @@ -484,10 +484,10 @@ CM.Sim.ResetBonus = function(possiblePresMax) { CM.Sim.CalculateGains(); curCPS = CM.Sim.cookiesPs; - + CM.Sim.CopyData(); } - + if (Game.cookiesEarned >= 1000000) CM.Sim.Win('Sacrifice'); if (Game.cookiesEarned >= 1000000000) CM.Sim.Win('Oblivion'); if (Game.cookiesEarned >= 1000000000000) CM.Sim.Win('From scratch'); @@ -498,25 +498,24 @@ CM.Sim.ResetBonus = function(possiblePresMax) { if (Game.cookiesEarned >= 1000000000000000000000000000) CM.Sim.Win('Obliterate'); if (Game.cookiesEarned >= 1000000000000000000000000000000) CM.Sim.Win('Negative void'); if (Game.cookiesEarned >= 1000000000000000000000000000000000) CM.Sim.Win('To crumbs, you say?'); - + CM.Sim.Upgrades['Heavenly chip secret'].bought = 1; CM.Sim.Upgrades['Heavenly cookie stand'].bought = 1; CM.Sim.Upgrades['Heavenly bakery'].bought = 1; CM.Sim.Upgrades['Heavenly confectionery'].bought = 1; CM.Sim.Upgrades['Heavenly key'].bought = 1; - + CM.Sim.prestige = possiblePresMax; - + lastAchievementsOwned = CM.Sim.AchievementsOwned; CM.Sim.CalculateGains(); - + CM.Sim.CheckOtherAchiev(); - + if (lastAchievementsOwned != CM.Sim.AchievementsOwned) { CM.Sim.CalculateGains(); } return (CM.Sim.cookiesPs - curCPS); } - From 71388411b5b04ae4ab245d737a19b1702bd2592b Mon Sep 17 00:00:00 2001 From: Aktanusa Date: Sun, 4 Mar 2018 18:15:32 -0500 Subject: [PATCH 10/18] Fixed Issues #153 and #158. Thanks to @Pantalaim0n and @CrackedP0t for the suggestion with the use of unsafeWindow but I rather use @cpeter256 version with window.eval instead. --- README.md | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index de05f72..c22627c 100644 --- a/README.md +++ b/README.md @@ -81,14 +81,16 @@ If you'd rather use the addon as a script via per example *Greasemonkey* or *Tam // @grant none // ==/UserScript== -(function() { +var code = "(" + (function() { var checkReady = setInterval(function() { if (typeof Game.ready !== 'undefined' && Game.ready) { - Game.LoadMod('https://aktanusa.github.io/CookieMonster/CookieMonster.js'); + Game.LoadMod('http://aktanusa.github.io/CookieMonster/CookieMonster.js'); clearInterval(checkReady); } }, 1000); -})(); +}).toString() + ")()"; + +window.eval(code); ``` If you are using the beta, use this instead: @@ -101,14 +103,16 @@ If you are using the beta, use this instead: // @grant none // ==/UserScript== -(function() { +var code = "(" + (function() { var checkReady = setInterval(function() { if (typeof Game.ready !== 'undefined' && Game.ready) { Game.LoadMod('https://aktanusa.github.io/CookieMonster/CookieMonsterBeta.js'); clearInterval(checkReady); } }, 1000); -})(); +}).toString() + ")()"; + +window.eval(code); ``` # Bugs and suggestions From 38b3c503fc2646f4f0e6adce895ba9be88cfaf9f Mon Sep 17 00:00:00 2001 From: Aktanusa Date: Sun, 4 Mar 2018 18:28:44 -0500 Subject: [PATCH 11/18] Change to Version 2.0045.1 --- src/Main.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Main.js b/src/Main.js index e5efcd2..2aeca4b 100644 --- a/src/Main.js +++ b/src/Main.js @@ -250,6 +250,6 @@ CM.HasReplaceNativeGrimoireDraw = false; CM.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkBuildColor: 0, UpBarColor: 1, CalcWrink: 0, CPSMode: 1, AvgCPSHist: 0, 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, Tooltip: 1, TooltipAmor: 0, ToolWarnCaut: 1, ToolWarnCautPos: 1, ToolWrink: 1, Stats: 1, UpStats: 1, TimeFormat: 0, SayTime: 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.0042'; -CM.VersionMinor = '3'; +CM.VersionMajor = '2.0045'; +CM.VersionMinor = '1'; From 3190d18d234b1d99e33bf81f2102ad21791e12d9 Mon Sep 17 00:00:00 2001 From: Aktanusa Date: Sun, 4 Mar 2018 18:31:48 -0500 Subject: [PATCH 12/18] Forgot CookieMonster.js again... --- CookieMonster.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/CookieMonster.js b/CookieMonster.js index 76f8e4a..e0b82c2 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -2748,8 +2748,8 @@ CM.HasReplaceNativeGrimoireDraw = false; CM.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkBuildColor: 0, UpBarColor: 1, CalcWrink: 0, CPSMode: 1, AvgCPSHist: 0, 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, Tooltip: 1, TooltipAmor: 0, ToolWarnCaut: 1, ToolWarnCautPos: 1, ToolWrink: 1, Stats: 1, UpStats: 1, TimeFormat: 0, SayTime: 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.0042'; -CM.VersionMinor = '3'; +CM.VersionMajor = '2.0045'; +CM.VersionMinor = '1'; /******* * Sim * From 2600ec040b346c0accbcb7c872626c455334c204 Mon Sep 17 00:00:00 2001 From: Aktanusa Date: Sun, 4 Mar 2018 19:15:27 -0500 Subject: [PATCH 13/18] Fix for Version 2.0045 of Cookie Clicker (Issue #161) --- CookieMonster.js | 3 +++ src/Sim.js | 3 +++ 2 files changed, 6 insertions(+) diff --git a/CookieMonster.js b/CookieMonster.js index e0b82c2..2e4df2f 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -3019,6 +3019,9 @@ CM.Sim.CalculateGains = function() { } mult *= eggMult; + // TODO Store lumps? + if (CM.Sim.Has('Sugar baking')) mult* = (1 +Math.min(100, Game.lumps) * 0.01); + if (CM.Sim.hasAura('Radiant Appetite')) mult *= 2; if (Game.hasAura('Dragon\'s Fortune')) { diff --git a/src/Sim.js b/src/Sim.js index 8c8ef44..711cb6b 100644 --- a/src/Sim.js +++ b/src/Sim.js @@ -266,6 +266,9 @@ CM.Sim.CalculateGains = function() { } mult *= eggMult; + // TODO Store lumps? + if (CM.Sim.Has('Sugar baking')) mult* = (1 +Math.min(100, Game.lumps) * 0.01); + if (CM.Sim.hasAura('Radiant Appetite')) mult *= 2; if (Game.hasAura('Dragon\'s Fortune')) { From 00e0b179a3500b248ac37fef56b73c1b45fce4dd Mon Sep 17 00:00:00 2001 From: Nico Date: Mon, 5 Mar 2018 16:44:10 +0100 Subject: [PATCH 14/18] Fixed typo, which ended in a bug --- CookieMonster.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CookieMonster.js b/CookieMonster.js index 2e4df2f..2d3716c 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -3020,7 +3020,7 @@ CM.Sim.CalculateGains = function() { mult *= eggMult; // TODO Store lumps? - if (CM.Sim.Has('Sugar baking')) mult* = (1 +Math.min(100, Game.lumps) * 0.01); + if (CM.Sim.Has('Sugar baking')) mult *= (1 +Math.min(100, Game.lumps) * 0.01); if (CM.Sim.hasAura('Radiant Appetite')) mult *= 2; From fcd4d9e0fc3e05b6c299bfb610225c9fde3cf72d Mon Sep 17 00:00:00 2001 From: Aktanusa Date: Mon, 5 Mar 2018 15:08:03 -0500 Subject: [PATCH 15/18] Format the line better and also fixed the source file that was fixed in Issue #166 --- CookieMonster.js | 2 +- src/Sim.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/CookieMonster.js b/CookieMonster.js index 2d3716c..b68d5de 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -3020,7 +3020,7 @@ CM.Sim.CalculateGains = function() { mult *= eggMult; // TODO Store lumps? - if (CM.Sim.Has('Sugar baking')) mult *= (1 +Math.min(100, Game.lumps) * 0.01); + if (CM.Sim.Has('Sugar baking')) mult *= (1 + Math.min(100, Game.lumps) * 0.01); if (CM.Sim.hasAura('Radiant Appetite')) mult *= 2; diff --git a/src/Sim.js b/src/Sim.js index 711cb6b..b6a8155 100644 --- a/src/Sim.js +++ b/src/Sim.js @@ -267,7 +267,7 @@ CM.Sim.CalculateGains = function() { mult *= eggMult; // TODO Store lumps? - if (CM.Sim.Has('Sugar baking')) mult* = (1 +Math.min(100, Game.lumps) * 0.01); + if (CM.Sim.Has('Sugar baking')) mult *= (1 + Math.min(100, Game.lumps) * 0.01); if (CM.Sim.hasAura('Radiant Appetite')) mult *= 2; From 23abe7256448c4ab99915fafba98ae2e5c8c69ff Mon Sep 17 00:00:00 2001 From: Aktanusa Date: Mon, 5 Mar 2018 16:09:58 -0500 Subject: [PATCH 16/18] Undo some of the merge changes that was unwanted --- CookieMonster.js | 13 ++++++++++--- src/Cache.js | 1 + src/Config.js | 3 ++- src/Data.js | 1 + src/Disp.js | 5 +++-- src/Header.js | 1 + src/Main.js | 1 + src/Sim.js | 1 + 8 files changed, 20 insertions(+), 6 deletions(-) diff --git a/CookieMonster.js b/CookieMonster.js index 3ad2a24..00f1d19 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -17,6 +17,7 @@ CM.Data = {}; CM.Disp = {}; CM.Sim = {}; + /********* * Cache * *********/ @@ -388,6 +389,7 @@ CM.Cache.ClicksDiff; CM.Cache.AvgCPS = -1; CM.Cache.AvgCPSChoEgg = -1; CM.Cache.AvgClicks = -1; + /********** * Config * **********/ @@ -527,7 +529,7 @@ CM.ConfigData.SeaSoundURL = {label: 'Season Special Sound URL:', desc: 'URL of t CM.ConfigData.GCTimer = {label: ['Golden Cookie Timer OFF', 'Golden Cookie Timer ON'], desc: 'A timer on the Golden Cookie when it has been spawned', toggle: true, func: function() {CM.Disp.ToggleGCTimer();}}; CM.ConfigData.Title = {label: ['Title OFF', 'Title ON', 'Title Pinned Tab Highlight'], desc: 'Update title with Golden Cookie/Season Popup timers; pinned tab highlight only changes the title when a Golden Cookie/Season Popup spawns', toggle: true}; CM.ConfigData.Favicon = {label: ['Favicon OFF', 'Favicon ON'], desc: 'Update favicon with Golden/Wrath Cookie', toggle: true, func: function() {CM.Disp.UpdateFavicon();}}; -CM.ConfigData.Tooltip = {label: ['Tooltip Information OFF', 'Tooltip Information ON'], desc: 'Extra information in tooltip for buildings/upgrades', toggle: true}; +CM.ConfigData.Tooltip = {label: ['Tooltip Information OFF', 'Tooltip Information ON'], desc: 'Extra information in tooltip for buildings/upgrades/grimoire', toggle: true}; CM.ConfigData.TooltipAmor = {label: ['Tooltip Amortization Information OFF', 'Tooltip Amortization Information ON'], desc: 'Add amortization information to buildings tooltip', toggle: true}; CM.ConfigData.ToolWarnCaut = {label: ['Tooltip Warning/Caution OFF', 'Tooltip Warning/Caution ON'], desc: 'A warning/caution when buying if it will put the bank under the amount needed for max "Lucky!"/"Lucky!" (Frenzy) rewards', toggle: true, func: function() {CM.Disp.ToggleToolWarnCaut();}}; CM.ConfigData.ToolWarnCautPos = {label: ['Tooltip Warning/Caution Position (Left)', 'Tooltip Warning/Caution Position (Bottom)'], desc: 'Placement of the warning/caution boxes', toggle: false, func: function() {CM.Disp.ToggleToolWarnCautPos();}}; @@ -537,6 +539,7 @@ CM.ConfigData.UpStats = {label: ['Statistics Update Rate (Default)', 'Statistics CM.ConfigData.TimeFormat = {label: ['Time XXd, XXh, XXm, XXs', 'Time XX:XX:XX:XX:XX'], desc: 'Change the time format', toggle: false}; CM.ConfigData.SayTime = {label: ['Format Time OFF', 'Format Time ON'], desc: 'Change how time is displayed in statistics', toggle: true, func: function() {CM.Disp.ToggleSayTime();}}; CM.ConfigData.Scale = {label: ['Game\'s Setting Scale', 'Metric', 'Short Scale', 'Scientific Notation'], desc: 'Change how long numbers are handled', toggle: false, func: function() {CM.Disp.RefreshScale();}}; + /******** * Data * ********/ @@ -544,6 +547,7 @@ CM.ConfigData.Scale = {label: ['Game\'s Setting Scale', 'Metric', 'Short Scale', CM.Data.HalloCookies = ['Skull cookies', 'Ghost cookies', 'Bat cookies', 'Slime cookies', 'Pumpkin cookies', 'Eyeball cookies', 'Spider cookies']; CM.Data.ChristCookies = ['Christmas tree biscuits', 'Snowflake biscuits', 'Snowman biscuits', 'Holly biscuits', 'Candy cane biscuits', 'Bell biscuits', 'Present biscuits']; CM.Data.ValCookies = ['Pure heart biscuits', 'Ardent heart biscuits', 'Sour heart biscuits', 'Weeping heart biscuits', 'Golden heart biscuits', 'Eternal heart biscuits']; + /******** * Disp * ********/ @@ -580,7 +584,7 @@ CM.Disp.FormatTime = function(time, format) { } str += s; } else { - if (time > 86400) return format ? 'Over 24 hours' : '>24h'; + if (time > 777600000) return format ? 'Over 9000 days!' : '>9000d'; time = Math.ceil(time); var d = Math.floor(time / 86400); var h = Math.floor(time % 86400 / 3600); @@ -610,7 +614,7 @@ CM.Disp.GetTimeColor = function(price, bank, cps, time) { text = '00:00:00:00:00'; } else { - text = 'Ready'; + text = 'Done!'; } } else { @@ -2493,6 +2497,7 @@ CM.Disp.TooltipWrinklerCache = []; for (var i in Game.wrinklers) { CM.Disp.TooltipWrinklerCache[i] = 0; } + /******** * Main * ********/ @@ -2747,6 +2752,7 @@ CM.ConfigPrefix = 'CMConfig'; CM.VersionMajor = '2.0045'; CM.VersionMinor = '1'; + /******* * Sim * *******/ @@ -3271,6 +3277,7 @@ CM.Sim.ResetBonus = function(possiblePresMax) { return (CM.Sim.cookiesPs - curCPS); } + /********** * Footer * **********/ diff --git a/src/Cache.js b/src/Cache.js index 4962419..8ad4537 100644 --- a/src/Cache.js +++ b/src/Cache.js @@ -369,3 +369,4 @@ CM.Cache.ClicksDiff; CM.Cache.AvgCPS = -1; CM.Cache.AvgCPSChoEgg = -1; CM.Cache.AvgClicks = -1; + diff --git a/src/Config.js b/src/Config.js index bb69de6..9e6172d 100644 --- a/src/Config.js +++ b/src/Config.js @@ -137,7 +137,7 @@ CM.ConfigData.SeaSoundURL = {label: 'Season Special Sound URL:', desc: 'URL of t CM.ConfigData.GCTimer = {label: ['Golden Cookie Timer OFF', 'Golden Cookie Timer ON'], desc: 'A timer on the Golden Cookie when it has been spawned', toggle: true, func: function() {CM.Disp.ToggleGCTimer();}}; CM.ConfigData.Title = {label: ['Title OFF', 'Title ON', 'Title Pinned Tab Highlight'], desc: 'Update title with Golden Cookie/Season Popup timers; pinned tab highlight only changes the title when a Golden Cookie/Season Popup spawns', toggle: true}; CM.ConfigData.Favicon = {label: ['Favicon OFF', 'Favicon ON'], desc: 'Update favicon with Golden/Wrath Cookie', toggle: true, func: function() {CM.Disp.UpdateFavicon();}}; -CM.ConfigData.Tooltip = {label: ['Tooltip Information OFF', 'Tooltip Information ON'], desc: 'Extra information in tooltip for buildings/upgrades', toggle: true}; +CM.ConfigData.Tooltip = {label: ['Tooltip Information OFF', 'Tooltip Information ON'], desc: 'Extra information in tooltip for buildings/upgrades/grimoire', toggle: true}; CM.ConfigData.TooltipAmor = {label: ['Tooltip Amortization Information OFF', 'Tooltip Amortization Information ON'], desc: 'Add amortization information to buildings tooltip', toggle: true}; CM.ConfigData.ToolWarnCaut = {label: ['Tooltip Warning/Caution OFF', 'Tooltip Warning/Caution ON'], desc: 'A warning/caution when buying if it will put the bank under the amount needed for max "Lucky!"/"Lucky!" (Frenzy) rewards', toggle: true, func: function() {CM.Disp.ToggleToolWarnCaut();}}; CM.ConfigData.ToolWarnCautPos = {label: ['Tooltip Warning/Caution Position (Left)', 'Tooltip Warning/Caution Position (Bottom)'], desc: 'Placement of the warning/caution boxes', toggle: false, func: function() {CM.Disp.ToggleToolWarnCautPos();}}; @@ -147,3 +147,4 @@ CM.ConfigData.UpStats = {label: ['Statistics Update Rate (Default)', 'Statistics CM.ConfigData.TimeFormat = {label: ['Time XXd, XXh, XXm, XXs', 'Time XX:XX:XX:XX:XX'], desc: 'Change the time format', toggle: false}; CM.ConfigData.SayTime = {label: ['Format Time OFF', 'Format Time ON'], desc: 'Change how time is displayed in statistics', toggle: true, func: function() {CM.Disp.ToggleSayTime();}}; CM.ConfigData.Scale = {label: ['Game\'s Setting Scale', 'Metric', 'Short Scale', 'Scientific Notation'], desc: 'Change how long numbers are handled', toggle: false, func: function() {CM.Disp.RefreshScale();}}; + diff --git a/src/Data.js b/src/Data.js index 4779b64..84571d8 100644 --- a/src/Data.js +++ b/src/Data.js @@ -5,3 +5,4 @@ CM.Data.HalloCookies = ['Skull cookies', 'Ghost cookies', 'Bat cookies', 'Slime cookies', 'Pumpkin cookies', 'Eyeball cookies', 'Spider cookies']; CM.Data.ChristCookies = ['Christmas tree biscuits', 'Snowflake biscuits', 'Snowman biscuits', 'Holly biscuits', 'Candy cane biscuits', 'Bell biscuits', 'Present biscuits']; CM.Data.ValCookies = ['Pure heart biscuits', 'Ardent heart biscuits', 'Sour heart biscuits', 'Weeping heart biscuits', 'Golden heart biscuits', 'Eternal heart biscuits']; + diff --git a/src/Disp.js b/src/Disp.js index 422721d..3467e50 100644 --- a/src/Disp.js +++ b/src/Disp.js @@ -34,7 +34,7 @@ CM.Disp.FormatTime = function(time, format) { } str += s; } else { - if (time > 86400) return format ? 'Over 24 hours' : '>24h'; + if (time > 777600000) return format ? 'Over 9000 days!' : '>9000d'; time = Math.ceil(time); var d = Math.floor(time / 86400); var h = Math.floor(time % 86400 / 3600); @@ -64,7 +64,7 @@ CM.Disp.GetTimeColor = function(price, bank, cps, time) { text = '00:00:00:00:00'; } else { - text = 'Ready'; + text = 'Done!'; } } else { @@ -1947,3 +1947,4 @@ CM.Disp.TooltipWrinklerCache = []; for (var i in Game.wrinklers) { CM.Disp.TooltipWrinklerCache[i] = 0; } + diff --git a/src/Header.js b/src/Header.js index 8f6f94a..7e91767 100644 --- a/src/Header.js +++ b/src/Header.js @@ -17,3 +17,4 @@ CM.Data = {}; CM.Disp = {}; CM.Sim = {}; + diff --git a/src/Main.js b/src/Main.js index 4420528..54e9461 100644 --- a/src/Main.js +++ b/src/Main.js @@ -252,3 +252,4 @@ CM.ConfigPrefix = 'CMConfig'; CM.VersionMajor = '2.0045'; CM.VersionMinor = '1'; + diff --git a/src/Sim.js b/src/Sim.js index 6cca70b..a89f0e8 100644 --- a/src/Sim.js +++ b/src/Sim.js @@ -522,3 +522,4 @@ CM.Sim.ResetBonus = function(possiblePresMax) { return (CM.Sim.cookiesPs - curCPS); } + From 3ec7b67c24fd8cfc111e1ba209464b90fa94bcf7 Mon Sep 17 00:00:00 2001 From: Aktanusa Date: Mon, 5 Mar 2018 16:11:41 -0500 Subject: [PATCH 17/18] Fix brainfart undo https --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index c22627c..5457758 100644 --- a/README.md +++ b/README.md @@ -84,7 +84,7 @@ If you'd rather use the addon as a script via per example *Greasemonkey* or *Tam var code = "(" + (function() { var checkReady = setInterval(function() { if (typeof Game.ready !== 'undefined' && Game.ready) { - Game.LoadMod('http://aktanusa.github.io/CookieMonster/CookieMonster.js'); + Game.LoadMod('https://aktanusa.github.io/CookieMonster/CookieMonster.js'); clearInterval(checkReady); } }, 1000); From 5689ffb36e5c2f2032ad4e95282843b75ee199ba Mon Sep 17 00:00:00 2001 From: Aktanusa Date: Mon, 5 Mar 2018 21:08:26 -0500 Subject: [PATCH 18/18] Revert tableLayout since it cuts off information --- CookieMonster.js | 5 +++-- src/Disp.js | 5 +++-- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/CookieMonster.js b/CookieMonster.js index 00f1d19..d7a641d 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -734,8 +734,9 @@ CM.Disp.CreateBotBar = function() { table.style.width = '100%'; table.style.textAlign = 'center'; table.style.whiteSpace = 'nowrap'; - table.style.tableLayout = 'fixed'; - table.style.overflow = 'hidden'; + // TODO figure a better way + //table.style.tableLayout = 'fixed'; + //table.style.overflow = 'hidden'; var tbody = document.createElement('tbody'); table.appendChild(tbody); diff --git a/src/Disp.js b/src/Disp.js index 3467e50..bb3e6e0 100644 --- a/src/Disp.js +++ b/src/Disp.js @@ -184,8 +184,9 @@ CM.Disp.CreateBotBar = function() { table.style.width = '100%'; table.style.textAlign = 'center'; table.style.whiteSpace = 'nowrap'; - table.style.tableLayout = 'fixed'; - table.style.overflow = 'hidden'; + // TODO figure a better way + //table.style.tableLayout = 'fixed'; + //table.style.overflow = 'hidden'; var tbody = document.createElement('tbody'); table.appendChild(tbody);