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 diff --git a/CookieMonster.js b/CookieMonster.js index 34b2844..d7a641d 100644 --- a/CookieMonster.js +++ b/CookieMonster.js @@ -21,11 +21,11 @@ CM.Sim = {}; /********* * Cache * *********/ - + 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); } @@ -50,10 +50,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 +142,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 +176,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 +193,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 +216,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 +260,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 +277,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 +285,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 +295,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 +312,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 +324,7 @@ CM.Cache.UpdateAvgCPS = function() { sortedGainChoEgg.pop(); cut--; } - + var totalGainBank = 0; var totalGainWrink = 0; var totalGainChoEgg = 0; @@ -335,9 +335,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; } @@ -401,7 +401,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 +448,8 @@ CM.LoadConfig = function() { } } } - else { // Default values - CM.RestoreDefault(); + else { // Default values + CM.RestoreDefault(); } } @@ -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();}}; @@ -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; } @@ -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); } @@ -729,14 +729,17 @@ 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'; + // TODO figure a better way + //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 +747,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 +761,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 +773,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 +795,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 +809,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 +828,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 +839,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 +848,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 +863,7 @@ CM.Disp.CreateTimerBar = function() { } div.appendChild(colorBar); } - + var timer = document.createElement('span'); timer.id = time; timer.style.marginLeft = '5px'; @@ -868,7 +871,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 +879,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 +887,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 +896,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 +905,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 +938,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 +957,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 +968,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 +997,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 +1023,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 +1041,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 +1067,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 +1110,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 +1120,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 +1134,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 +1143,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 +1162,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 +1247,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); } @@ -1301,10 +1304,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 { @@ -1327,7 +1330,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 +1358,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 +1383,7 @@ CM.Disp.CheckSeasonPopup = function() { break; } } - + CM.Disp.Flash(3); CM.Disp.PlaySound(CM.Config.SeaSoundURL); } @@ -1393,7 +1396,7 @@ CM.Disp.UpdateTitle = function() { } else if (CM.Config.Title == 1) { var addSP = false; - + var titleGC; var titleSP; if (CM.Disp.lastGoldenCookieState) { @@ -1419,12 +1422,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 +1487,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 +1509,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 +1535,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 +1559,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 +1569,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 +1596,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 +1620,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 +1652,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 +1669,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 +1690,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 +1715,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 +1744,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 +1755,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 +1767,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 +1827,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 +1854,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 +1868,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 +1905,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 +1962,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 +1983,7 @@ CM.Disp.AddMenu = function() { div.textContent = 'Cookie Monster Goodies'; return div; } - + if (Game.onMenu == 'prefs') { CM.Disp.AddMenuPref(title); } @@ -2011,7 +2014,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 +2122,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 +2156,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 +2168,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 +2176,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 +2192,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 +2251,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 +2303,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 +2322,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 +2330,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 +2340,7 @@ CM.Disp.UpdateTooltip = function() { recover.textContent = recoverColor.text; recover.className = CM.Disp.colorTextPre + recoverColor.color; } - + l('CMTooltipArea').appendChild(tooltip); } } @@ -2499,7 +2502,7 @@ for (var i in Game.wrinklers) { /******** * Main * ********/ - + CM.ReplaceNative = function() { CM.Backup.Beautify = Beautify; Beautify = CM.Disp.Beautify; @@ -2510,7 +2513,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')); @@ -2518,7 +2521,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() { @@ -2526,7 +2529,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) { @@ -2554,7 +2557,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') { @@ -2562,24 +2565,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(); } @@ -2625,19 +2628,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) { @@ -2648,15 +2651,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(); @@ -2664,11 +2667,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(); @@ -2679,10 +2682,10 @@ CM.Loop = function() { // Change menu refresh interval CM.Disp.RefreshMenu(); } - + // Check Golden Cookies CM.Disp.CheckGoldenCookie(); - + // Check Season Popup CM.Disp.CheckSeasonPopup(); @@ -2698,7 +2701,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(); @@ -2718,11 +2721,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(); @@ -2745,11 +2748,11 @@ 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'; -CM.VersionMinor = '2'; +CM.VersionMajor = '2.0045'; +CM.VersionMinor = '1'; /******* * Sim * @@ -2832,8 +2835,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; } @@ -2885,7 +2888,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]; @@ -2994,7 +2997,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; @@ -3018,7 +3021,10 @@ CM.Sim.CalculateGains = function() { eggMult *= CM.Cache.CentEgg; } 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')) { @@ -3029,7 +3035,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); } @@ -3104,16 +3110,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; @@ -3127,13 +3133,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'); @@ -3146,21 +3152,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) { @@ -3192,17 +3198,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; } @@ -3221,12 +3227,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; @@ -3237,10 +3243,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'); @@ -3251,21 +3257,21 @@ 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(); } diff --git a/README.md b/README.md index f1809ec..5457758 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'); }()); ``` @@ -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('http://aktanusa.github.io/CookieMonster/CookieMonster.js'); + Game.LoadMod('https://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('http://aktanusa.github.io/CookieMonster/CookieMonsterBeta.js'); + Game.LoadMod('https://aktanusa.github.io/CookieMonster/CookieMonsterBeta.js'); clearInterval(checkReady); } }, 1000); -})(); +}).toString() + ")()"; + +window.eval(code); ``` # Bugs and suggestions @@ -129,7 +133,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 diff --git a/src/Cache.js b/src/Cache.js index 39c4ae3..8ad4537 100644 --- a/src/Cache.js +++ b/src/Cache.js @@ -1,11 +1,11 @@ /********* * Cache * *********/ - + 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); } @@ -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; } diff --git a/src/Config.js b/src/Config.js index 7f7e59b..9e6172d 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(); } } @@ -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();}}; diff --git a/src/Disp.js b/src/Disp.js index a91aab5..bb3e6e0 100644 --- a/src/Disp.js +++ b/src/Disp.js @@ -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; } @@ -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); } @@ -179,14 +179,17 @@ 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'; + // TODO figure a better way + //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 +197,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 +211,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 +223,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 +245,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 +259,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 +278,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 +289,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 +298,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 +313,7 @@ CM.Disp.CreateTimerBar = function() { } div.appendChild(colorBar); } - + var timer = document.createElement('span'); timer.id = time; timer.style.marginLeft = '5px'; @@ -318,7 +321,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 +329,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 +337,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 +346,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 +355,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 +388,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 +407,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 +418,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 +447,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 +473,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 +491,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 +517,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 +560,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 +570,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 +584,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 +593,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 +612,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 +697,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); } @@ -751,10 +754,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 { @@ -777,7 +780,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 +808,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 +833,7 @@ CM.Disp.CheckSeasonPopup = function() { break; } } - + CM.Disp.Flash(3); CM.Disp.PlaySound(CM.Config.SeaSoundURL); } @@ -843,7 +846,7 @@ CM.Disp.UpdateTitle = function() { } else if (CM.Config.Title == 1) { var addSP = false; - + var titleGC; var titleSP; if (CM.Disp.lastGoldenCookieState) { @@ -869,12 +872,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 +937,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 +959,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 +985,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 +1009,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 +1019,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,22 +1046,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'); @@ -1067,9 +1070,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();}; } @@ -1099,12 +1102,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'; @@ -1116,7 +1119,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 + ' ')); @@ -1137,7 +1140,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; @@ -1162,7 +1165,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'; @@ -1191,7 +1194,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; @@ -1202,7 +1205,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; @@ -1214,13 +1217,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'; @@ -1274,9 +1277,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))); @@ -1301,9 +1304,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) + ' ')); @@ -1315,7 +1318,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) { @@ -1352,9 +1355,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) { @@ -1409,10 +1412,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)))); @@ -1430,7 +1433,7 @@ CM.Disp.AddMenu = function() { div.textContent = 'Cookie Monster Goodies'; return div; } - + if (Game.onMenu == 'prefs') { CM.Disp.AddMenuPref(title); } @@ -1461,7 +1464,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; @@ -1569,7 +1572,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) { @@ -1603,11 +1606,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'); @@ -1615,7 +1618,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'; @@ -1623,7 +1626,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'; @@ -1639,21 +1642,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')) { @@ -1698,7 +1701,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; @@ -1750,10 +1753,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'; @@ -1769,7 +1772,7 @@ CM.Disp.UpdateTooltip = function() { div.textContent = text; return div; } - + tooltip.appendChild(header('Time Left')); var time = document.createElement('div'); time.id = 'CMTooltipTime'; @@ -1777,7 +1780,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'); @@ -1787,7 +1790,7 @@ CM.Disp.UpdateTooltip = function() { recover.textContent = recoverColor.text; recover.className = CM.Disp.colorTextPre + recoverColor.color; } - + l('CMTooltipArea').appendChild(tooltip); } } diff --git a/src/Main.js b/src/Main.js index f4ba933..54e9461 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(); @@ -247,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, 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'; -CM.VersionMinor = '2'; +CM.VersionMajor = '2.0045'; +CM.VersionMinor = '1'; diff --git a/src/Sim.js b/src/Sim.js index 8c8ef44..a89f0e8 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,10 @@ CM.Sim.CalculateGains = function() { eggMult *= CM.Cache.CentEgg; } 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')) { @@ -276,7 +279,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 +354,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 +377,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 +396,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 +442,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 +471,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 +487,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,21 +501,21 @@ 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(); }