Compare commits
44 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5689ffb36e | ||
|
|
3ec7b67c24 | ||
|
|
23abe72564 | ||
|
|
5266d8e4dc | ||
|
|
ebd0e929e2 | ||
|
|
fcd4d9e0fc | ||
|
|
41cd7688ea | ||
|
|
00e0b179a3 | ||
|
|
2600ec040b | ||
|
|
3190d18d23 | ||
|
|
38b3c503fc | ||
|
|
71388411b5 | ||
|
|
67eac9fde2 | ||
|
|
bd0cd9900d | ||
|
|
4ad6cc9fe0 | ||
|
|
e59b69e3f2 | ||
|
|
78df5491a0 | ||
|
|
de0d148dd0 | ||
|
|
f9b4dd4ada | ||
|
|
0f8b5b7da7 | ||
|
|
7295e0ea76 | ||
|
|
010e065dd7 | ||
|
|
816c566442 | ||
|
|
f32b1d5685 | ||
|
|
9df807a4ae | ||
|
|
bd2b59efde | ||
|
|
04549b5e21 | ||
|
|
e5039b588b | ||
|
|
5a9dc8b9fe | ||
|
|
f773a9595a | ||
|
|
362e87610e | ||
|
|
b16510c6ed | ||
|
|
92ff50d3a3 | ||
|
|
1633dfb283 | ||
|
|
80bb731f17 | ||
|
|
ba387bddc6 | ||
|
|
197fceaddc | ||
|
|
cad42578a9 | ||
|
|
446f1e767c | ||
|
|
6ac602a067 | ||
|
|
37107ae621 | ||
|
|
687cb9a4c9 | ||
|
|
2176b9b436 | ||
|
|
e061caa2e4 |
@@ -1,2 +1,2 @@
|
|||||||
#!/bin/sh
|
#!/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
|
||||||
|
|||||||
306
CookieMonster.js
306
CookieMonster.js
@@ -25,7 +25,7 @@ CM.Sim = {};
|
|||||||
CM.Cache.AddQueue = function() {
|
CM.Cache.AddQueue = function() {
|
||||||
CM.Cache.Queue = document.createElement('script');
|
CM.Cache.Queue = document.createElement('script');
|
||||||
CM.Cache.Queue.type = 'text/javascript';
|
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);
|
document.head.appendChild(CM.Cache.Queue);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -76,6 +76,13 @@ CM.Cache.RemakeWrinkBank = function() {
|
|||||||
totalSucked += sucked;
|
totalSucked += sucked;
|
||||||
}
|
}
|
||||||
CM.Cache.WrinkBank = totalSucked;
|
CM.Cache.WrinkBank = totalSucked;
|
||||||
|
CM.Cache.WrinkGodBank = totalSucked;
|
||||||
|
if (Game.hasGod) {
|
||||||
|
var godLvl = Game.hasGod('scorn');
|
||||||
|
if (godLvl == 2) CM.Cache.WrinkGodBank = CM.Cache.WrinkGodBank * 1.15 / 1.1;
|
||||||
|
else if (godLvl == 3) CM.Cache.WrinkGodBank = CM.Cache.WrinkGodBank * 1.15 / 1.05;
|
||||||
|
else if (godLvl != 1) CM.Cache.WrinkGodBank *= 1.15;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CM.Cache.RemakeBuildingsPP = function() {
|
CM.Cache.RemakeBuildingsPP = function() {
|
||||||
@@ -256,14 +263,14 @@ CM.Cache.UpdateAvgCPS = function() {
|
|||||||
if (CM.Cache.lastDate != currDate) {
|
if (CM.Cache.lastDate != currDate) {
|
||||||
var choEggTotal = Game.cookies + CM.Cache.SellForChoEgg;
|
var choEggTotal = Game.cookies + CM.Cache.SellForChoEgg;
|
||||||
if (Game.cpsSucked > 0) {
|
if (Game.cpsSucked > 0) {
|
||||||
choEggTotal += CM.Cache.WrinkBank;
|
choEggTotal += CM.Cache.WrinkGodBank;
|
||||||
}
|
}
|
||||||
choEggTotal *= 0.05;
|
choEggTotal *= 0.05;
|
||||||
|
|
||||||
if (CM.Cache.lastDate != -1) {
|
if (CM.Cache.lastDate != -1) {
|
||||||
var timeDiff = currDate - CM.Cache.lastDate
|
var timeDiff = currDate - CM.Cache.lastDate
|
||||||
var bankDiffAvg = Math.max(0, (Game.cookies - CM.Cache.lastCookies)) / timeDiff;
|
var bankDiffAvg = Math.max(0, (Game.cookies - CM.Cache.lastCookies)) / timeDiff;
|
||||||
var wrinkDiffAvg = (CM.Cache.WrinkBank - CM.Cache.lastWrinkCookies) / timeDiff;
|
var wrinkDiffAvg = Math.max(0, (CM.Cache.WrinkBank - CM.Cache.lastWrinkCookies)) / timeDiff;
|
||||||
var choEggDiffAvg = Math.max(0,(choEggTotal - CM.Cache.lastChoEgg)) / timeDiff;
|
var choEggDiffAvg = Math.max(0,(choEggTotal - CM.Cache.lastChoEgg)) / timeDiff;
|
||||||
var clicksDiffAvg = (Game.cookieClicks - CM.Cache.lastClicks) / timeDiff;
|
var clicksDiffAvg = (Game.cookieClicks - CM.Cache.lastClicks) / timeDiff;
|
||||||
for (var i = 0; i < timeDiff; i++) {
|
for (var i = 0; i < timeDiff; i++) {
|
||||||
@@ -289,20 +296,50 @@ CM.Cache.UpdateAvgCPS = function() {
|
|||||||
CM.Cache.lastChoEgg = choEggTotal;
|
CM.Cache.lastChoEgg = choEggTotal;
|
||||||
CM.Cache.lastClicks = Game.cookieClicks;
|
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
|
||||||
|
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));
|
||||||
|
sortedGainChoEgg.push(CM.Cache.ChoEggDiff.get(i));
|
||||||
|
}
|
||||||
|
|
||||||
|
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();
|
||||||
|
sortedGainWrink.shift();
|
||||||
|
sortedGainWrink.pop();
|
||||||
|
sortedGainChoEgg.shift();
|
||||||
|
sortedGainChoEgg.pop();
|
||||||
|
cut--;
|
||||||
|
}
|
||||||
|
|
||||||
var totalGainBank = 0;
|
var totalGainBank = 0;
|
||||||
var totalGainWrink = 0;
|
var totalGainWrink = 0;
|
||||||
var totalGainChoEgg = 0;
|
var totalGainChoEgg = 0;
|
||||||
var cpsLength = Math.min(CM.Cache.CookiesDiff.getLength(), CM.Disp.times[CM.Config.AvgCPSHist] * 60);
|
|
||||||
// Assumes the queues are the same length
|
|
||||||
for (var i = CM.Cache.CookiesDiff.getLength() - cpsLength; i < CM.Cache.CookiesDiff.getLength(); i++) {
|
|
||||||
totalGainBank += CM.Cache.CookiesDiff.get(i);
|
|
||||||
totalGainWrink += CM.Cache.WrinkDiff.get(i);
|
|
||||||
totalGainChoEgg += CM.Cache.ChoEggDiff.get(i);
|
|
||||||
}
|
|
||||||
CM.Cache.AvgCPS = (totalGainBank + (CM.Config.CalcWrink ? totalGainWrink : 0)) / cpsLength;
|
|
||||||
|
|
||||||
if ((Game.HasUnlocked('Chocolate egg') && !Game.Has('Chocolate egg')) || CM.Config.CalcWrink == 0) {
|
for (var i = 0; i < sortedGainBank.length; i++) {
|
||||||
CM.Cache.AvgCPSChoEgg = (totalGainBank + totalGainWrink + totalGainChoEgg) / cpsLength;
|
totalGainBank += sortedGainBank[i];
|
||||||
|
totalGainWrink += sortedGainWrink[i];
|
||||||
|
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;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
CM.Cache.AvgCPSChoEgg = CM.Cache.AvgCPS;
|
CM.Cache.AvgCPSChoEgg = CM.Cache.AvgCPS;
|
||||||
@@ -321,6 +358,7 @@ CM.Cache.min = -1;
|
|||||||
CM.Cache.max = -1;
|
CM.Cache.max = -1;
|
||||||
CM.Cache.mid = -1;
|
CM.Cache.mid = -1;
|
||||||
CM.Cache.WrinkBank = -1;
|
CM.Cache.WrinkBank = -1;
|
||||||
|
CM.Cache.WrinkGodBank = -1;
|
||||||
CM.Cache.NoGoldSwitchCookiesPS = 0;
|
CM.Cache.NoGoldSwitchCookiesPS = 0;
|
||||||
CM.Cache.Lucky = 0;
|
CM.Cache.Lucky = 0;
|
||||||
CM.Cache.LuckyReward = 0;
|
CM.Cache.LuckyReward = 0;
|
||||||
@@ -475,7 +513,7 @@ CM.ConfigData.BuildColor = {label: ['Building Colors OFF', 'Building Colors ON']
|
|||||||
CM.ConfigData.BulkBuildColor = {label: ['Bulk Building Colors (Single Buildings Color)', 'Bulk Building Colors (Calculated Color)'], desc: 'Color code bulk buildings based on single buildings color or calculated bulk value color', toggle: false, func: function() {CM.Disp.UpdateBuildings();}};
|
CM.ConfigData.BulkBuildColor = {label: ['Bulk Building Colors (Single Buildings Color)', 'Bulk Building Colors (Calculated Color)'], desc: 'Color code bulk buildings based on single buildings color or calculated bulk value color', toggle: false, func: function() {CM.Disp.UpdateBuildings();}};
|
||||||
CM.ConfigData.UpBarColor = {label: ['Upgrade Bar/Colors OFF', 'Upgrade Bar/Colors ON'], desc: 'Color code upgrades and add a counter', toggle: true, func: function() {CM.Disp.ToggleUpBarColor();}};
|
CM.ConfigData.UpBarColor = {label: ['Upgrade Bar/Colors OFF', 'Upgrade Bar/Colors ON'], desc: 'Color code upgrades and add a counter', toggle: true, func: function() {CM.Disp.ToggleUpBarColor();}};
|
||||||
CM.ConfigData.Colors = {desc: {Blue: 'Color Blue. Used to show better than best PP building, for Click Frenzy bar, and for various labels', Green: 'Color Green. Used to show best PP building, for Blood Frenzy bar, and for various labels', Yellow: 'Color Yellow. Used to show between best and worst PP buildings closer to best, for Frenzy bar, and for various labels', Orange: 'Color Orange. Used to show between best and worst PP buildings closer to worst, for Next Reindeer bar, and for various labels', Red: 'Color Red. Used to show worst PP building, for Clot bar, and for various labels', Purple: 'Color Purple. Used to show worse than worst PP building, for Next Cookie bar, and for various labels', Gray: 'Color Gray. Used to show negative or infinity PP, and for Next Cookie/Next Reindeer bar', Pink: 'Color Pink. Used for Dragonflight bar', Brown: 'Color Brown. Used for Dragon Harvest bar'}, func: function() {CM.Disp.UpdateColors();}};
|
CM.ConfigData.Colors = {desc: {Blue: 'Color Blue. Used to show better than best PP building, for Click Frenzy bar, and for various labels', Green: 'Color Green. Used to show best PP building, for Blood Frenzy bar, and for various labels', Yellow: 'Color Yellow. Used to show between best and worst PP buildings closer to best, for Frenzy bar, and for various labels', Orange: 'Color Orange. Used to show between best and worst PP buildings closer to worst, for Next Reindeer bar, and for various labels', Red: 'Color Red. Used to show worst PP building, for Clot bar, and for various labels', Purple: 'Color Purple. Used to show worse than worst PP building, for Next Cookie bar, and for various labels', Gray: 'Color Gray. Used to show negative or infinity PP, and for Next Cookie/Next Reindeer bar', Pink: 'Color Pink. Used for Dragonflight bar', Brown: 'Color Brown. Used for Dragon Harvest bar'}, func: function() {CM.Disp.UpdateColors();}};
|
||||||
CM.ConfigData.CalcWrink = {label: ['Calculate with Wrinklers OFF', 'Calculate with Wrinklers ON'], desc: 'Calculate times and average Cookies Per Second with Wrinkers', toggle: true};
|
CM.ConfigData.CalcWrink = {label: ['Calculate with Wrinklers OFF', 'Calculate with Wrinklers ON'], desc: 'Calculate times and average Cookies Per Second with Wrinklers', toggle: true};
|
||||||
CM.ConfigData.CPSMode = {label: ['Current Cookies Per Second', 'Average Cookies Per Second'], desc: 'Calculate times using current Cookies Per Second or average Cookies Per Second', toggle: false};
|
CM.ConfigData.CPSMode = {label: ['Current Cookies Per Second', 'Average Cookies Per Second'], desc: 'Calculate times using current Cookies Per Second or average Cookies Per Second', toggle: false};
|
||||||
CM.ConfigData.AvgCPSHist = {label: ['Average CPS for past 1m', 'Average CPS for past 5m', 'Average CPS for past 10m', 'Average CPS for past 15m', 'Average CPS for past 30m'], desc: 'How much time average Cookies Per Second should consider', toggle: false};
|
CM.ConfigData.AvgCPSHist = {label: ['Average CPS for past 1m', 'Average CPS for past 5m', 'Average CPS for past 10m', 'Average CPS for past 15m', 'Average CPS for past 30m'], desc: 'How much time average Cookies Per Second should consider', toggle: false};
|
||||||
CM.ConfigData.AvgClicksHist = {label: ['Average Cookie Clicks for past 1s', 'Average Cookie Clicks for past 5s', 'Average Cookie Clicks for past 10s', 'Average Cookie Clicks for past 15s', 'Average Cookie Clicks for past 30s'], desc: 'How much time average Cookie Clicks should consider', toggle: false};
|
CM.ConfigData.AvgClicksHist = {label: ['Average Cookie Clicks for past 1s', 'Average Cookie Clicks for past 5s', 'Average Cookie Clicks for past 10s', 'Average Cookie Clicks for past 15s', 'Average Cookie Clicks for past 30s'], desc: 'How much time average Cookie Clicks should consider', toggle: false};
|
||||||
@@ -491,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.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.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.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.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.ToolWarnCaut = {label: ['Tooltip Warning/Caution OFF', 'Tooltip Warning/Caution ON'], desc: 'A warning/caution when buying if it will put the bank under the amount needed for max "Lucky!"/"Lucky!" (Frenzy) rewards', toggle: true, func: function() {CM.Disp.ToggleToolWarnCaut();}};
|
||||||
CM.ConfigData.ToolWarnCautPos = {label: ['Tooltip Warning/Caution Position (Left)', 'Tooltip Warning/Caution Position (Bottom)'], desc: 'Placement of the warning/caution boxes', toggle: false, func: function() {CM.Disp.ToggleToolWarnCautPos();}};
|
CM.ConfigData.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();}};
|
||||||
@@ -567,7 +605,7 @@ CM.Disp.FormatTime = function(time, format) {
|
|||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
CM.Disp.GetTimeColor = function(price, bank, cps) {
|
CM.Disp.GetTimeColor = function(price, bank, cps, time) {
|
||||||
var color;
|
var color;
|
||||||
var text;
|
var text;
|
||||||
if (bank >= price) {
|
if (bank >= price) {
|
||||||
@@ -579,8 +617,13 @@ CM.Disp.GetTimeColor = function(price, bank, cps) {
|
|||||||
text = 'Done!';
|
text = 'Done!';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
if (typeof time !== 'undefined') {
|
||||||
|
var time = time;
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
var time = (price - bank) / cps;
|
var time = (price - bank) / cps;
|
||||||
|
}
|
||||||
text = CM.Disp.FormatTime(time);
|
text = CM.Disp.FormatTime(time);
|
||||||
if (time > 300) {
|
if (time > 300) {
|
||||||
color = CM.Disp.colorRed;
|
color = CM.Disp.colorRed;
|
||||||
@@ -660,7 +703,7 @@ CM.Disp.GetConfigDisplay = function(config) {
|
|||||||
CM.Disp.AddJscolor = function() {
|
CM.Disp.AddJscolor = function() {
|
||||||
CM.Disp.Jscolor = document.createElement('script');
|
CM.Disp.Jscolor = document.createElement('script');
|
||||||
CM.Disp.Jscolor.type = 'text/javascript';
|
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);
|
document.head.appendChild(CM.Disp.Jscolor);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -691,6 +734,9 @@ CM.Disp.CreateBotBar = function() {
|
|||||||
table.style.width = '100%';
|
table.style.width = '100%';
|
||||||
table.style.textAlign = 'center';
|
table.style.textAlign = 'center';
|
||||||
table.style.whiteSpace = 'nowrap';
|
table.style.whiteSpace = 'nowrap';
|
||||||
|
// TODO figure a better way
|
||||||
|
//table.style.tableLayout = 'fixed';
|
||||||
|
//table.style.overflow = 'hidden';
|
||||||
var tbody = document.createElement('tbody');
|
var tbody = document.createElement('tbody');
|
||||||
table.appendChild(tbody);
|
table.appendChild(tbody);
|
||||||
|
|
||||||
@@ -1258,10 +1304,10 @@ CM.Disp.CreateFavicon = function() {
|
|||||||
CM.Disp.UpdateFavicon = function() {
|
CM.Disp.UpdateFavicon = function() {
|
||||||
if (CM.Config.Favicon == 1 && CM.Disp.lastGoldenCookieState) {
|
if (CM.Config.Favicon == 1 && CM.Disp.lastGoldenCookieState) {
|
||||||
if (CM.Disp.goldenShimmer.wrath) {
|
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 {
|
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 {
|
else {
|
||||||
@@ -1786,8 +1832,8 @@ CM.Disp.AddMenuStats = function(title) {
|
|||||||
|
|
||||||
stats.appendChild(header('Prestige', 'Prestige'));
|
stats.appendChild(header('Prestige', 'Prestige'));
|
||||||
if (CM.Config.StatsPref.Prestige) {
|
if (CM.Config.StatsPref.Prestige) {
|
||||||
var possiblePresMax = Math.floor(Game.HowMuchPrestige(Game.cookiesEarned + Game.cookiesReset + CM.Cache.WrinkBank + (choEgg ? CM.Cache.lastChoEgg : 0)));
|
var possiblePresMax = Math.floor(Game.HowMuchPrestige(Game.cookiesEarned + Game.cookiesReset + CM.Cache.WrinkGodBank + (choEgg ? CM.Cache.lastChoEgg : 0)));
|
||||||
var neededCook = Game.HowManyCookiesReset(possiblePresMax + 1) - (Game.cookiesEarned + Game.cookiesReset + CM.Cache.WrinkBank + (choEgg ? CM.Cache.lastChoEgg : 0));
|
var neededCook = Game.HowManyCookiesReset(possiblePresMax + 1) - (Game.cookiesEarned + Game.cookiesReset + CM.Cache.WrinkGodBank + (choEgg ? CM.Cache.lastChoEgg : 0));
|
||||||
|
|
||||||
stats.appendChild(listing(listingQuest('Prestige Level (CUR / MAX)', 'PrestMaxTooltipPlaceholder'), document.createTextNode(Beautify(Game.prestige) + ' / ' + Beautify(possiblePresMax))));
|
stats.appendChild(listing(listingQuest('Prestige Level (CUR / MAX)', 'PrestMaxTooltipPlaceholder'), document.createTextNode(Beautify(Game.prestige) + ' / ' + Beautify(possiblePresMax))));
|
||||||
var cookiesNextFrag = document.createDocumentFragment();
|
var cookiesNextFrag = document.createDocumentFragment();
|
||||||
@@ -2026,6 +2072,15 @@ CM.Disp.ToggleToolWarnCautPos = function() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CM.Disp.CalculateGrimoireRefillTime = function(currentMagic, maxMagic, targetMagic) {
|
||||||
|
var count = 0;
|
||||||
|
while (currentMagic < targetMagic) {
|
||||||
|
currentMagic += Math.max(0.002, Math.pow(currentMagic / Math.max(maxMagic, 100), 0.5)) * 0.002;
|
||||||
|
count++;
|
||||||
|
}
|
||||||
|
return count / Game.fps;
|
||||||
|
}
|
||||||
|
|
||||||
CM.Disp.AddTooltipBuild = function() {
|
CM.Disp.AddTooltipBuild = function() {
|
||||||
CM.Disp.TooltipBuildBack = [];
|
CM.Disp.TooltipBuildBack = [];
|
||||||
for (var i in Game.Objects) {
|
for (var i in Game.Objects) {
|
||||||
@@ -2048,6 +2103,18 @@ CM.Disp.AddTooltipUpgrade = function() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CM.Disp.AddTooltipGrimoire = function() {
|
||||||
|
if (Game.Objects['Wizard tower'].minigameLoaded) {
|
||||||
|
CM.Disp.TooltipGrimoireBack = [];
|
||||||
|
for (var i in Game.Objects['Wizard tower'].minigame.spellsById) {
|
||||||
|
if (l('grimoireSpell' + i).onmouseover != null) {
|
||||||
|
CM.Disp.TooltipGrimoireBack[i] = l('grimoireSpell' + i).onmouseover;
|
||||||
|
eval('l(\'grimoireSpell\' + i).onmouseover = function() {Game.tooltip.dynamic = 1; Game.tooltip.draw(this, function() {return CM.Disp.Tooltip(\'g\', \'' + i + '\');}, \'this\'); Game.tooltip.wobble();}');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
CM.Disp.Tooltip = function(type, name) {
|
CM.Disp.Tooltip = function(type, name) {
|
||||||
if (type == 'b') {
|
if (type == 'b') {
|
||||||
l('tooltip').innerHTML = Game.Objects[name].tooltip();
|
l('tooltip').innerHTML = Game.Objects[name].tooltip();
|
||||||
@@ -2082,16 +2149,19 @@ CM.Disp.Tooltip = function(type, name) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else { // Upgrades
|
else if (type == 'u') {
|
||||||
if (!Game.UpgradesInStore[name]) return '';
|
if (!Game.UpgradesInStore[name]) return '';
|
||||||
l('tooltip').innerHTML = Game.crate(Game.UpgradesInStore[name], 'store', undefined, undefined, 1)();
|
l('tooltip').innerHTML = Game.crate(Game.UpgradesInStore[name], 'store', undefined, undefined, 1)();
|
||||||
}
|
}
|
||||||
|
else { // Grimoire
|
||||||
|
l('tooltip').innerHTML = Game.Objects['Wizard tower'].minigame.spellTooltip(name)();
|
||||||
|
}
|
||||||
|
|
||||||
var area = document.createElement('div');
|
var area = document.createElement('div');
|
||||||
area.id = 'CMTooltipArea';
|
area.id = 'CMTooltipArea';
|
||||||
l('tooltip').appendChild(area);
|
l('tooltip').appendChild(area);
|
||||||
|
|
||||||
if (CM.Config.Tooltip == 1 && (type != 'b' || Game.buyMode == 1)) {
|
if (CM.Config.Tooltip == 1 && (type == 'u' || (type == 'b' && Game.buyMode == 1))) {
|
||||||
l('tooltip').firstChild.style.paddingBottom = '4px';
|
l('tooltip').firstChild.style.paddingBottom = '4px';
|
||||||
var tooltip = document.createElement('div');
|
var tooltip = document.createElement('div');
|
||||||
tooltip.style.border = '1px solid';
|
tooltip.style.border = '1px solid';
|
||||||
@@ -2106,6 +2176,7 @@ CM.Disp.Tooltip = function(type, name) {
|
|||||||
div.textContent = text;
|
div.textContent = text;
|
||||||
return div;
|
return div;
|
||||||
}
|
}
|
||||||
|
|
||||||
tooltip.appendChild(header('Bonus Income'));
|
tooltip.appendChild(header('Bonus Income'));
|
||||||
var income = document.createElement('div');
|
var income = document.createElement('div');
|
||||||
income.style.marginBottom = '4px';
|
income.style.marginBottom = '4px';
|
||||||
@@ -2122,7 +2193,7 @@ CM.Disp.Tooltip = function(type, name) {
|
|||||||
time.id = 'CMTooltipTime';
|
time.id = 'CMTooltipTime';
|
||||||
tooltip.appendChild(time);
|
tooltip.appendChild(time);
|
||||||
|
|
||||||
l('tooltip').appendChild(tooltip);
|
area.appendChild(tooltip);
|
||||||
}
|
}
|
||||||
|
|
||||||
CM.Disp.tooltipType = type;
|
CM.Disp.tooltipType = type;
|
||||||
@@ -2136,6 +2207,7 @@ CM.Disp.Tooltip = function(type, name) {
|
|||||||
CM.Disp.UpdateTooltip = function() {
|
CM.Disp.UpdateTooltip = function() {
|
||||||
if (l('tooltipAnchor').style.display != 'none' && l('CMTooltipArea') != null) {
|
if (l('tooltipAnchor').style.display != 'none' && l('CMTooltipArea') != null) {
|
||||||
|
|
||||||
|
if (CM.Disp.tooltipType == 'b' || CM.Disp.tooltipType == 'u') {
|
||||||
// Error checking
|
// 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')) {
|
if (CM.Disp.tooltipType == 'u' && (typeof Game.UpgradesInStore[CM.Disp.tooltipName] === 'undefined' || typeof CM.Cache.Upgrades[Game.UpgradesInStore[CM.Disp.tooltipName].name] === 'undefined')) {
|
||||||
return;
|
return;
|
||||||
@@ -2225,6 +2297,54 @@ CM.Disp.UpdateTooltip = function() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else { // Grimoire
|
||||||
|
l('CMDispTooltipWarn').style.display = 'none';
|
||||||
|
l('CMDispTooltipCaut').style.display = 'none';
|
||||||
|
|
||||||
|
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';
|
||||||
|
tooltip.style.padding = '4px';
|
||||||
|
tooltip.style.margin = '0px -4px';
|
||||||
|
tooltip.id = 'CMTooltipBorder';
|
||||||
|
tooltip.className = CM.Disp.colorTextPre + CM.Disp.colorGray;
|
||||||
|
|
||||||
|
var header = function(text) {
|
||||||
|
var div = document.createElement('div');
|
||||||
|
div.style.fontWeight = 'bold';
|
||||||
|
div.className = CM.Disp.colorTextPre + CM.Disp.colorBlue;
|
||||||
|
div.textContent = text;
|
||||||
|
return div;
|
||||||
|
}
|
||||||
|
|
||||||
|
tooltip.appendChild(header('Time Left'));
|
||||||
|
var time = document.createElement('div');
|
||||||
|
time.id = 'CMTooltipTime';
|
||||||
|
tooltip.appendChild(time);
|
||||||
|
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');
|
||||||
|
recover.id = 'CMTooltipRecover';
|
||||||
|
tooltip.appendChild(recover);
|
||||||
|
var recoverColor = CM.Disp.GetTimeColor(minigame.magic, Math.max(0, minigame.magic - spellCost), undefined, CM.Disp.CalculateGrimoireRefillTime(Math.max(0, minigame.magic - spellCost), minigame.magicM, minigame.magic));
|
||||||
|
recover.textContent = recoverColor.text;
|
||||||
|
recover.className = CM.Disp.colorTextPre + recoverColor.color;
|
||||||
|
}
|
||||||
|
|
||||||
|
l('CMTooltipArea').appendChild(tooltip);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CM.Disp.DrawTooltipWarnCaut = function() {
|
CM.Disp.DrawTooltipWarnCaut = function() {
|
||||||
@@ -2391,7 +2511,7 @@ CM.ReplaceNative = function() {
|
|||||||
Game.CalculateGains = function() {
|
Game.CalculateGains = function() {
|
||||||
CM.Backup.CalculateGains();
|
CM.Backup.CalculateGains();
|
||||||
CM.Sim.DoSims = 1;
|
CM.Sim.DoSims = 1;
|
||||||
CM.Sim.Date = new Date().getTime();
|
CM.Sim.Date = Date.now();
|
||||||
}
|
}
|
||||||
|
|
||||||
CM.Backup.tooltip = {};
|
CM.Backup.tooltip = {};
|
||||||
@@ -2403,7 +2523,7 @@ CM.ReplaceNative = function() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
CM.Backup.tooltip.update = Game.tooltip.update;
|
CM.Backup.tooltip.update = Game.tooltip.update;
|
||||||
eval('CM.Backup.tooltip.updateMod = ' + Game.tooltip.update.toString().split('this').join('Game.tooltip'));
|
eval('CM.Backup.tooltip.updateMod = ' + Game.tooltip.update.toString().split('this.').join('Game.tooltip.'));
|
||||||
Game.tooltip.update = function() {
|
Game.tooltip.update = function() {
|
||||||
CM.Backup.tooltip.updateMod();
|
CM.Backup.tooltip.updateMod();
|
||||||
CM.Disp.UpdateTooltipWarnCaut();
|
CM.Disp.UpdateTooltipWarnCaut();
|
||||||
@@ -2423,6 +2543,14 @@ CM.ReplaceNative = function() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Probably better to load per minigame
|
||||||
|
CM.Backup.scriptLoaded = Game.scriptLoaded;
|
||||||
|
Game.scriptLoaded = function(who, script) {
|
||||||
|
CM.Backup.scriptLoaded(who, script);
|
||||||
|
CM.Disp.AddTooltipGrimoire()
|
||||||
|
CM.ReplaceNativeGrimoire();
|
||||||
|
}
|
||||||
|
|
||||||
CM.Backup.RebuildUpgrades = Game.RebuildUpgrades;
|
CM.Backup.RebuildUpgrades = Game.RebuildUpgrades;
|
||||||
Game.RebuildUpgrades = function() {
|
Game.RebuildUpgrades = function() {
|
||||||
CM.Backup.RebuildUpgrades();
|
CM.Backup.RebuildUpgrades();
|
||||||
@@ -2460,6 +2588,40 @@ CM.ReplaceNative = function() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CM.ReplaceNativeGrimoire = function() {
|
||||||
|
CM.ReplaceNativeGrimoireLaunch();
|
||||||
|
CM.ReplaceNativeGrimoireDraw();
|
||||||
|
}
|
||||||
|
|
||||||
|
CM.ReplaceNativeGrimoireLaunch = function() {
|
||||||
|
if (!CM.HasReplaceNativeGrimoireLaunch && Game.Objects['Wizard tower'].minigameLoaded) {
|
||||||
|
var minigame = Game.Objects['Wizard tower'].minigame;
|
||||||
|
CM.Backup.GrimoireLaunch = minigame.launch;
|
||||||
|
eval('CM.Backup.GrimoireLaunchMod = ' + minigame.launch.toString().split('=this').join('= Game.Objects[\'Wizard tower\'].minigame'));
|
||||||
|
Game.Objects['Wizard tower'].minigame.launch = function() {
|
||||||
|
CM.Backup.GrimoireLaunchMod();
|
||||||
|
CM.Disp.AddTooltipGrimoire();
|
||||||
|
CM.HasReplaceNativeGrimoireDraw = false;
|
||||||
|
CM.ReplaceNativeGrimoireDraw();
|
||||||
|
}
|
||||||
|
CM.HasReplaceNativeGrimoireLaunch = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CM.ReplaceNativeGrimoireDraw = function() {
|
||||||
|
if (!CM.HasReplaceNativeGrimoireDraw && Game.Objects['Wizard tower'].minigameLoaded) {
|
||||||
|
var minigame = Game.Objects['Wizard tower'].minigame;
|
||||||
|
CM.Backup.GrimoireDraw = minigame.draw;
|
||||||
|
Game.Objects['Wizard tower'].minigame.draw = function() {
|
||||||
|
CM.Backup.GrimoireDraw();
|
||||||
|
if (minigame.magic < minigame.magicM) {
|
||||||
|
minigame.magicBarTextL.innerHTML += ' (' + CM.Disp.FormatTime(CM.Disp.CalculateGrimoireRefillTime(minigame.magic, minigame.magicM, minigame.magicM)) + ')';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
CM.HasReplaceNativeGrimoireDraw = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
CM.Loop = function() {
|
CM.Loop = function() {
|
||||||
if (CM.Disp.lastAscendState != Game.OnAscend) {
|
if (CM.Disp.lastAscendState != Game.OnAscend) {
|
||||||
CM.Disp.lastAscendState = Game.OnAscend;
|
CM.Disp.lastAscendState = Game.OnAscend;
|
||||||
@@ -2559,16 +2721,18 @@ CM.DelayInit = function() {
|
|||||||
CM.Disp.CreateFavicon();
|
CM.Disp.CreateFavicon();
|
||||||
CM.Disp.CreateGCTimer();
|
CM.Disp.CreateGCTimer();
|
||||||
CM.Disp.CreateTooltip('GoldCookTooltipPlaceholder', 'Calculated with Golden Switch off', '200px');
|
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, selling all buildings with Earth Shatterer aura, and buying Chocolate egg', '310px');
|
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', 'Not calculated with cookies gained from wrinklers or Chocolate egg', '200px');
|
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, selling all buildings with Earth Shatterer aura, and buying Chocolate egg', '310px');
|
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 at 100% of its potential and from reset achievements if you have the same buildings/upgrades after reset', '340px');
|
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, selling all buildings with Earth Shatterer aura, and then buying Chocolate egg', '300px');
|
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.CreateTooltipWarnCaut();
|
||||||
CM.Disp.AddTooltipBuild();
|
CM.Disp.AddTooltipBuild();
|
||||||
|
CM.Disp.AddTooltipGrimoire();
|
||||||
CM.Disp.AddWrinklerAreaDetect();
|
CM.Disp.AddWrinklerAreaDetect();
|
||||||
CM.Cache.InitCookiesDiff();
|
CM.Cache.InitCookiesDiff();
|
||||||
CM.ReplaceNative();
|
CM.ReplaceNative();
|
||||||
|
CM.ReplaceNativeGrimoire();
|
||||||
Game.CalculateGains();
|
Game.CalculateGains();
|
||||||
CM.LoadConfig(); // Must be after all things are created!
|
CM.LoadConfig(); // Must be after all things are created!
|
||||||
CM.Disp.lastAscendState = Game.OnAscend;
|
CM.Disp.lastAscendState = Game.OnAscend;
|
||||||
@@ -2581,11 +2745,14 @@ CM.DelayInit = function() {
|
|||||||
Game.Win('Third-party');
|
Game.Win('Third-party');
|
||||||
}
|
}
|
||||||
|
|
||||||
CM.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkBuildColor: 0, UpBarColor: 1, CalcWrink: 1, CPSMode: 1, AvgCPSHist: 2, AvgClicksHist: 2, 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.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: '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.ConfigPrefix = 'CMConfig';
|
||||||
|
|
||||||
CM.VersionMajor = '2.0034';
|
CM.VersionMajor = '2.0045';
|
||||||
CM.VersionMinor = '2';
|
CM.VersionMinor = '1';
|
||||||
|
|
||||||
/*******
|
/*******
|
||||||
* Sim *
|
* Sim *
|
||||||
@@ -2665,7 +2832,7 @@ CM.Sim.Win = function(what) {
|
|||||||
|
|
||||||
eval('CM.Sim.HasAchiev = ' + Game.HasAchiev.toString().split('Game').join('CM.Sim'));
|
eval('CM.Sim.HasAchiev = ' + Game.HasAchiev.toString().split('Game').join('CM.Sim'));
|
||||||
|
|
||||||
eval('CM.Sim.GetHeavenlyMultiplier = ' + Game.GetHeavenlyMultiplier.toString().split('Game').join('CM.Sim'));
|
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) {
|
CM.Sim.hasAura = function(what) {
|
||||||
if (Game.dragonAuras[CM.Sim.dragonAura].name == what || Game.dragonAuras[CM.Sim.dragonAura2].name == what)
|
if (Game.dragonAuras[CM.Sim.dragonAura].name == what || Game.dragonAuras[CM.Sim.dragonAura2].name == what)
|
||||||
@@ -2717,7 +2884,7 @@ CM.Sim.CopyData = function() {
|
|||||||
CM.Sim.UpgradesOwned = Game.UpgradesOwned;
|
CM.Sim.UpgradesOwned = Game.UpgradesOwned;
|
||||||
CM.Sim.pledges = Game.pledges;
|
CM.Sim.pledges = Game.pledges;
|
||||||
CM.Sim.AchievementsOwned = Game.AchievementsOwned;
|
CM.Sim.AchievementsOwned = Game.AchievementsOwned;
|
||||||
CM.Sim.heavenlyPower = Game.heavenlyPower;
|
CM.Sim.heavenlyPower = Game.heavenlyPower; // Unneeded?
|
||||||
CM.Sim.prestige = Game.prestige;
|
CM.Sim.prestige = Game.prestige;
|
||||||
CM.Sim.dragonAura = Game.dragonAura;
|
CM.Sim.dragonAura = Game.dragonAura;
|
||||||
CM.Sim.dragonAura2 = Game.dragonAura2;
|
CM.Sim.dragonAura2 = Game.dragonAura2;
|
||||||
@@ -2829,6 +2996,8 @@ CM.Sim.CalculateGains = function() {
|
|||||||
if (CM.Sim.Has('Kitten accountants')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult);
|
if (CM.Sim.Has('Kitten accountants')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult);
|
||||||
if (CM.Sim.Has('Kitten specialists')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult);
|
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 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 angels')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.1 * milkMult);
|
if (CM.Sim.Has('Kitten angels')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.1 * milkMult);
|
||||||
|
|
||||||
var eggMult = 1;
|
var eggMult = 1;
|
||||||
@@ -2853,9 +3022,20 @@ CM.Sim.CalculateGains = function() {
|
|||||||
}
|
}
|
||||||
mult *= eggMult;
|
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 (CM.Sim.hasAura('Radiant Appetite')) mult *= 2;
|
||||||
|
|
||||||
|
if (Game.hasAura('Dragon\'s Fortune')) {
|
||||||
|
var n = Game.shimmerTypes['golden'].n;
|
||||||
|
for (var i = 0; i < n; i++) {
|
||||||
|
mult *= 2.11;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
var rawCookiesPs = CM.Sim.cookiesPs * mult;
|
var rawCookiesPs = CM.Sim.cookiesPs * mult;
|
||||||
|
|
||||||
for (var i in Game.CpsAchievements) {
|
for (var i in Game.CpsAchievements) {
|
||||||
if (rawCookiesPs >= Game.CpsAchievements[i].threshold) CM.Sim.Win(Game.CpsAchievements[i].name);
|
if (rawCookiesPs >= Game.CpsAchievements[i].threshold) CM.Sim.Win(Game.CpsAchievements[i].name);
|
||||||
}
|
}
|
||||||
@@ -2887,7 +3067,7 @@ CM.Sim.CalculateGains = function() {
|
|||||||
};
|
};
|
||||||
|
|
||||||
CM.Sim.CheckOtherAchiev = function() {
|
CM.Sim.CheckOtherAchiev = function() {
|
||||||
var grandmas=0;
|
var grandmas = 0;
|
||||||
if (CM.Sim.Has('Farmer grandmas')) grandmas++;
|
if (CM.Sim.Has('Farmer grandmas')) grandmas++;
|
||||||
if (CM.Sim.Has('Worker grandmas')) grandmas++;
|
if (CM.Sim.Has('Worker grandmas')) grandmas++;
|
||||||
if (CM.Sim.Has('Miner grandmas')) grandmas++;
|
if (CM.Sim.Has('Miner grandmas')) grandmas++;
|
||||||
@@ -2900,6 +3080,7 @@ CM.Sim.CheckOtherAchiev = function() {
|
|||||||
if (CM.Sim.Has('Banker grandmas')) grandmas++;
|
if (CM.Sim.Has('Banker grandmas')) grandmas++;
|
||||||
if (CM.Sim.Has('Priestess grandmas')) grandmas++;
|
if (CM.Sim.Has('Priestess grandmas')) grandmas++;
|
||||||
if (CM.Sim.Has('Witch grandmas')) grandmas++;
|
if (CM.Sim.Has('Witch grandmas')) grandmas++;
|
||||||
|
if (CM.Sim.Has('Lucky grandmas')) grandmas++;
|
||||||
if (!CM.Sim.HasAchiev('Elder') && grandmas >= 7) CM.Sim.Win('Elder');
|
if (!CM.Sim.HasAchiev('Elder') && grandmas >= 7) CM.Sim.Win('Elder');
|
||||||
|
|
||||||
var buildingsOwned = 0;
|
var buildingsOwned = 0;
|
||||||
@@ -3049,45 +3230,22 @@ CM.Sim.ResetBonus = function(possiblePresMax) {
|
|||||||
|
|
||||||
// Calculate CPS with all Heavenly upgrades
|
// Calculate CPS with all Heavenly upgrades
|
||||||
var curCPS = Game.cookiesPs;
|
var curCPS = Game.cookiesPs;
|
||||||
if (CM.Sim.Upgrades['Heavenly chip secret'].bought == 0 || CM.Sim.Upgrades['Heavenly cookie stand'].bought == 0 || CM.Sim.Upgrades['Heavenly bakery'].bought == 0 || CM.Sim.Upgrades['Heavenly confectionery'].bought == 0 || CM.Sim.Upgrades['Heavenly key'].bought == 0) {
|
|
||||||
CM.Sim.CopyData();
|
CM.Sim.CopyData();
|
||||||
|
|
||||||
if (CM.Sim.Upgrades['Heavenly chip secret'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly chip secret'].bought = 1;
|
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly cookie stand'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly cookie stand'].bought = 1;
|
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly bakery'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly bakery'].bought = 1;
|
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly confectionery'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly confectionery'].bought = 1;
|
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly key'].bought == 0) {
|
if (CM.Sim.Upgrades['Heavenly key'].bought == 0) {
|
||||||
|
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.Upgrades['Heavenly key'].bought = 1;
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
CM.Sim.Win('Wholesome');
|
|
||||||
}
|
|
||||||
|
|
||||||
lastAchievementsOwned = CM.Sim.AchievementsOwned;
|
|
||||||
|
|
||||||
CM.Sim.CalculateGains();
|
CM.Sim.CalculateGains();
|
||||||
|
|
||||||
CM.Sim.CheckOtherAchiev();
|
|
||||||
|
|
||||||
if (lastAchievementsOwned != CM.Sim.AchievementsOwned) {
|
|
||||||
CM.Sim.CalculateGains();
|
|
||||||
}
|
|
||||||
|
|
||||||
curCPS = CM.Sim.cookiesPs;
|
curCPS = CM.Sim.cookiesPs;
|
||||||
}
|
|
||||||
|
|
||||||
CM.Sim.CopyData();
|
CM.Sim.CopyData();
|
||||||
|
}
|
||||||
|
|
||||||
if (Game.cookiesEarned >= 1000000) CM.Sim.Win('Sacrifice');
|
if (Game.cookiesEarned >= 1000000) CM.Sim.Win('Sacrifice');
|
||||||
if (Game.cookiesEarned >= 1000000000) CM.Sim.Win('Oblivion');
|
if (Game.cookiesEarned >= 1000000000) CM.Sim.Win('Oblivion');
|
||||||
@@ -3100,27 +3258,11 @@ CM.Sim.ResetBonus = function(possiblePresMax) {
|
|||||||
if (Game.cookiesEarned >= 1000000000000000000000000000000) CM.Sim.Win('Negative void');
|
if (Game.cookiesEarned >= 1000000000000000000000000000000) CM.Sim.Win('Negative void');
|
||||||
if (Game.cookiesEarned >= 1000000000000000000000000000000000) CM.Sim.Win('To crumbs, you say?');
|
if (Game.cookiesEarned >= 1000000000000000000000000000000000) CM.Sim.Win('To crumbs, you say?');
|
||||||
|
|
||||||
if (CM.Sim.Upgrades['Heavenly chip secret'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly chip secret'].bought = 1;
|
CM.Sim.Upgrades['Heavenly chip secret'].bought = 1;
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly cookie stand'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly cookie stand'].bought = 1;
|
CM.Sim.Upgrades['Heavenly cookie stand'].bought = 1;
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly bakery'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly bakery'].bought = 1;
|
CM.Sim.Upgrades['Heavenly bakery'].bought = 1;
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly confectionery'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly confectionery'].bought = 1;
|
CM.Sim.Upgrades['Heavenly confectionery'].bought = 1;
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly key'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly key'].bought = 1;
|
CM.Sim.Upgrades['Heavenly key'].bought = 1;
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
CM.Sim.Win('Wholesome');
|
|
||||||
}
|
|
||||||
|
|
||||||
CM.Sim.prestige = possiblePresMax;
|
CM.Sim.prestige = possiblePresMax;
|
||||||
|
|
||||||
|
|||||||
22
README.md
22
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
|
||||||
javascript: (function () {
|
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
|
||||||
javascript: (function () {
|
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
|
// @grant none
|
||||||
// ==/UserScript==
|
// ==/UserScript==
|
||||||
|
|
||||||
(function() {
|
var code = "(" + (function() {
|
||||||
var checkReady = setInterval(function() {
|
var checkReady = setInterval(function() {
|
||||||
if (typeof Game.ready !== 'undefined' && Game.ready) {
|
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);
|
clearInterval(checkReady);
|
||||||
}
|
}
|
||||||
}, 1000);
|
}, 1000);
|
||||||
})();
|
}).toString() + ")()";
|
||||||
|
|
||||||
|
window.eval(code);
|
||||||
```
|
```
|
||||||
If you are using the beta, use this instead:
|
If you are using the beta, use this instead:
|
||||||
|
|
||||||
@@ -101,14 +103,16 @@ If you are using the beta, use this instead:
|
|||||||
// @grant none
|
// @grant none
|
||||||
// ==/UserScript==
|
// ==/UserScript==
|
||||||
|
|
||||||
(function() {
|
var code = "(" + (function() {
|
||||||
var checkReady = setInterval(function() {
|
var checkReady = setInterval(function() {
|
||||||
if (typeof Game.ready !== 'undefined' && Game.ready) {
|
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);
|
clearInterval(checkReady);
|
||||||
}
|
}
|
||||||
}, 1000);
|
}, 1000);
|
||||||
})();
|
}).toString() + ")()";
|
||||||
|
|
||||||
|
window.eval(code);
|
||||||
```
|
```
|
||||||
|
|
||||||
# Bugs and suggestions
|
# Bugs and suggestions
|
||||||
@@ -129,7 +133,7 @@ All suggestions are welcome, even the smallest ones.
|
|||||||
|
|
||||||
# Contributors
|
# 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
|
* **[Maxime Fabre](https://github.com/Anahkiasen)**: Previous maintainer
|
||||||
* **[Alderi Tokori](http://forum.dashnet.org/profile/Alderi)**: ROI calculations (unused now)
|
* **[Alderi Tokori](http://forum.dashnet.org/profile/Alderi)**: ROI calculations (unused now)
|
||||||
* **[Alhifar](https://github.com/Alhifar)**: Missed Golden Cookie Stat
|
* **[Alhifar](https://github.com/Alhifar)**: Missed Golden Cookie Stat
|
||||||
|
|||||||
64
src/Cache.js
64
src/Cache.js
@@ -5,7 +5,7 @@
|
|||||||
CM.Cache.AddQueue = function() {
|
CM.Cache.AddQueue = function() {
|
||||||
CM.Cache.Queue = document.createElement('script');
|
CM.Cache.Queue = document.createElement('script');
|
||||||
CM.Cache.Queue.type = 'text/javascript';
|
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);
|
document.head.appendChild(CM.Cache.Queue);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -56,6 +56,13 @@ CM.Cache.RemakeWrinkBank = function() {
|
|||||||
totalSucked += sucked;
|
totalSucked += sucked;
|
||||||
}
|
}
|
||||||
CM.Cache.WrinkBank = totalSucked;
|
CM.Cache.WrinkBank = totalSucked;
|
||||||
|
CM.Cache.WrinkGodBank = totalSucked;
|
||||||
|
if (Game.hasGod) {
|
||||||
|
var godLvl = Game.hasGod('scorn');
|
||||||
|
if (godLvl == 2) CM.Cache.WrinkGodBank = CM.Cache.WrinkGodBank * 1.15 / 1.1;
|
||||||
|
else if (godLvl == 3) CM.Cache.WrinkGodBank = CM.Cache.WrinkGodBank * 1.15 / 1.05;
|
||||||
|
else if (godLvl != 1) CM.Cache.WrinkGodBank *= 1.15;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CM.Cache.RemakeBuildingsPP = function() {
|
CM.Cache.RemakeBuildingsPP = function() {
|
||||||
@@ -236,14 +243,14 @@ CM.Cache.UpdateAvgCPS = function() {
|
|||||||
if (CM.Cache.lastDate != currDate) {
|
if (CM.Cache.lastDate != currDate) {
|
||||||
var choEggTotal = Game.cookies + CM.Cache.SellForChoEgg;
|
var choEggTotal = Game.cookies + CM.Cache.SellForChoEgg;
|
||||||
if (Game.cpsSucked > 0) {
|
if (Game.cpsSucked > 0) {
|
||||||
choEggTotal += CM.Cache.WrinkBank;
|
choEggTotal += CM.Cache.WrinkGodBank;
|
||||||
}
|
}
|
||||||
choEggTotal *= 0.05;
|
choEggTotal *= 0.05;
|
||||||
|
|
||||||
if (CM.Cache.lastDate != -1) {
|
if (CM.Cache.lastDate != -1) {
|
||||||
var timeDiff = currDate - CM.Cache.lastDate
|
var timeDiff = currDate - CM.Cache.lastDate
|
||||||
var bankDiffAvg = Math.max(0, (Game.cookies - CM.Cache.lastCookies)) / timeDiff;
|
var bankDiffAvg = Math.max(0, (Game.cookies - CM.Cache.lastCookies)) / timeDiff;
|
||||||
var wrinkDiffAvg = (CM.Cache.WrinkBank - CM.Cache.lastWrinkCookies) / timeDiff;
|
var wrinkDiffAvg = Math.max(0, (CM.Cache.WrinkBank - CM.Cache.lastWrinkCookies)) / timeDiff;
|
||||||
var choEggDiffAvg = Math.max(0,(choEggTotal - CM.Cache.lastChoEgg)) / timeDiff;
|
var choEggDiffAvg = Math.max(0,(choEggTotal - CM.Cache.lastChoEgg)) / timeDiff;
|
||||||
var clicksDiffAvg = (Game.cookieClicks - CM.Cache.lastClicks) / timeDiff;
|
var clicksDiffAvg = (Game.cookieClicks - CM.Cache.lastClicks) / timeDiff;
|
||||||
for (var i = 0; i < timeDiff; i++) {
|
for (var i = 0; i < timeDiff; i++) {
|
||||||
@@ -269,20 +276,50 @@ CM.Cache.UpdateAvgCPS = function() {
|
|||||||
CM.Cache.lastChoEgg = choEggTotal;
|
CM.Cache.lastChoEgg = choEggTotal;
|
||||||
CM.Cache.lastClicks = Game.cookieClicks;
|
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
|
||||||
|
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));
|
||||||
|
sortedGainChoEgg.push(CM.Cache.ChoEggDiff.get(i));
|
||||||
|
}
|
||||||
|
|
||||||
|
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();
|
||||||
|
sortedGainWrink.shift();
|
||||||
|
sortedGainWrink.pop();
|
||||||
|
sortedGainChoEgg.shift();
|
||||||
|
sortedGainChoEgg.pop();
|
||||||
|
cut--;
|
||||||
|
}
|
||||||
|
|
||||||
var totalGainBank = 0;
|
var totalGainBank = 0;
|
||||||
var totalGainWrink = 0;
|
var totalGainWrink = 0;
|
||||||
var totalGainChoEgg = 0;
|
var totalGainChoEgg = 0;
|
||||||
var cpsLength = Math.min(CM.Cache.CookiesDiff.getLength(), CM.Disp.times[CM.Config.AvgCPSHist] * 60);
|
|
||||||
// Assumes the queues are the same length
|
|
||||||
for (var i = CM.Cache.CookiesDiff.getLength() - cpsLength; i < CM.Cache.CookiesDiff.getLength(); i++) {
|
|
||||||
totalGainBank += CM.Cache.CookiesDiff.get(i);
|
|
||||||
totalGainWrink += CM.Cache.WrinkDiff.get(i);
|
|
||||||
totalGainChoEgg += CM.Cache.ChoEggDiff.get(i);
|
|
||||||
}
|
|
||||||
CM.Cache.AvgCPS = (totalGainBank + (CM.Config.CalcWrink ? totalGainWrink : 0)) / cpsLength;
|
|
||||||
|
|
||||||
if ((Game.HasUnlocked('Chocolate egg') && !Game.Has('Chocolate egg')) || CM.Config.CalcWrink == 0) {
|
for (var i = 0; i < sortedGainBank.length; i++) {
|
||||||
CM.Cache.AvgCPSChoEgg = (totalGainBank + totalGainWrink + totalGainChoEgg) / cpsLength;
|
totalGainBank += sortedGainBank[i];
|
||||||
|
totalGainWrink += sortedGainWrink[i];
|
||||||
|
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;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
CM.Cache.AvgCPSChoEgg = CM.Cache.AvgCPS;
|
CM.Cache.AvgCPSChoEgg = CM.Cache.AvgCPS;
|
||||||
@@ -301,6 +338,7 @@ CM.Cache.min = -1;
|
|||||||
CM.Cache.max = -1;
|
CM.Cache.max = -1;
|
||||||
CM.Cache.mid = -1;
|
CM.Cache.mid = -1;
|
||||||
CM.Cache.WrinkBank = -1;
|
CM.Cache.WrinkBank = -1;
|
||||||
|
CM.Cache.WrinkGodBank = -1;
|
||||||
CM.Cache.NoGoldSwitchCookiesPS = 0;
|
CM.Cache.NoGoldSwitchCookiesPS = 0;
|
||||||
CM.Cache.Lucky = 0;
|
CM.Cache.Lucky = 0;
|
||||||
CM.Cache.LuckyReward = 0;
|
CM.Cache.LuckyReward = 0;
|
||||||
|
|||||||
@@ -121,7 +121,7 @@ CM.ConfigData.BuildColor = {label: ['Building Colors OFF', 'Building Colors ON']
|
|||||||
CM.ConfigData.BulkBuildColor = {label: ['Bulk Building Colors (Single Buildings Color)', 'Bulk Building Colors (Calculated Color)'], desc: 'Color code bulk buildings based on single buildings color or calculated bulk value color', toggle: false, func: function() {CM.Disp.UpdateBuildings();}};
|
CM.ConfigData.BulkBuildColor = {label: ['Bulk Building Colors (Single Buildings Color)', 'Bulk Building Colors (Calculated Color)'], desc: 'Color code bulk buildings based on single buildings color or calculated bulk value color', toggle: false, func: function() {CM.Disp.UpdateBuildings();}};
|
||||||
CM.ConfigData.UpBarColor = {label: ['Upgrade Bar/Colors OFF', 'Upgrade Bar/Colors ON'], desc: 'Color code upgrades and add a counter', toggle: true, func: function() {CM.Disp.ToggleUpBarColor();}};
|
CM.ConfigData.UpBarColor = {label: ['Upgrade Bar/Colors OFF', 'Upgrade Bar/Colors ON'], desc: 'Color code upgrades and add a counter', toggle: true, func: function() {CM.Disp.ToggleUpBarColor();}};
|
||||||
CM.ConfigData.Colors = {desc: {Blue: 'Color Blue. Used to show better than best PP building, for Click Frenzy bar, and for various labels', Green: 'Color Green. Used to show best PP building, for Blood Frenzy bar, and for various labels', Yellow: 'Color Yellow. Used to show between best and worst PP buildings closer to best, for Frenzy bar, and for various labels', Orange: 'Color Orange. Used to show between best and worst PP buildings closer to worst, for Next Reindeer bar, and for various labels', Red: 'Color Red. Used to show worst PP building, for Clot bar, and for various labels', Purple: 'Color Purple. Used to show worse than worst PP building, for Next Cookie bar, and for various labels', Gray: 'Color Gray. Used to show negative or infinity PP, and for Next Cookie/Next Reindeer bar', Pink: 'Color Pink. Used for Dragonflight bar', Brown: 'Color Brown. Used for Dragon Harvest bar'}, func: function() {CM.Disp.UpdateColors();}};
|
CM.ConfigData.Colors = {desc: {Blue: 'Color Blue. Used to show better than best PP building, for Click Frenzy bar, and for various labels', Green: 'Color Green. Used to show best PP building, for Blood Frenzy bar, and for various labels', Yellow: 'Color Yellow. Used to show between best and worst PP buildings closer to best, for Frenzy bar, and for various labels', Orange: 'Color Orange. Used to show between best and worst PP buildings closer to worst, for Next Reindeer bar, and for various labels', Red: 'Color Red. Used to show worst PP building, for Clot bar, and for various labels', Purple: 'Color Purple. Used to show worse than worst PP building, for Next Cookie bar, and for various labels', Gray: 'Color Gray. Used to show negative or infinity PP, and for Next Cookie/Next Reindeer bar', Pink: 'Color Pink. Used for Dragonflight bar', Brown: 'Color Brown. Used for Dragon Harvest bar'}, func: function() {CM.Disp.UpdateColors();}};
|
||||||
CM.ConfigData.CalcWrink = {label: ['Calculate with Wrinklers OFF', 'Calculate with Wrinklers ON'], desc: 'Calculate times and average Cookies Per Second with Wrinkers', toggle: true};
|
CM.ConfigData.CalcWrink = {label: ['Calculate with Wrinklers OFF', 'Calculate with Wrinklers ON'], desc: 'Calculate times and average Cookies Per Second with Wrinklers', toggle: true};
|
||||||
CM.ConfigData.CPSMode = {label: ['Current Cookies Per Second', 'Average Cookies Per Second'], desc: 'Calculate times using current Cookies Per Second or average Cookies Per Second', toggle: false};
|
CM.ConfigData.CPSMode = {label: ['Current Cookies Per Second', 'Average Cookies Per Second'], desc: 'Calculate times using current Cookies Per Second or average Cookies Per Second', toggle: false};
|
||||||
CM.ConfigData.AvgCPSHist = {label: ['Average CPS for past 1m', 'Average CPS for past 5m', 'Average CPS for past 10m', 'Average CPS for past 15m', 'Average CPS for past 30m'], desc: 'How much time average Cookies Per Second should consider', toggle: false};
|
CM.ConfigData.AvgCPSHist = {label: ['Average CPS for past 1m', 'Average CPS for past 5m', 'Average CPS for past 10m', 'Average CPS for past 15m', 'Average CPS for past 30m'], desc: 'How much time average Cookies Per Second should consider', toggle: false};
|
||||||
CM.ConfigData.AvgClicksHist = {label: ['Average Cookie Clicks for past 1s', 'Average Cookie Clicks for past 5s', 'Average Cookie Clicks for past 10s', 'Average Cookie Clicks for past 15s', 'Average Cookie Clicks for past 30s'], desc: 'How much time average Cookie Clicks should consider', toggle: false};
|
CM.ConfigData.AvgClicksHist = {label: ['Average Cookie Clicks for past 1s', 'Average Cookie Clicks for past 5s', 'Average Cookie Clicks for past 10s', 'Average Cookie Clicks for past 15s', 'Average Cookie Clicks for past 30s'], desc: 'How much time average Cookie Clicks should consider', toggle: false};
|
||||||
@@ -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.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.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.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.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.ToolWarnCaut = {label: ['Tooltip Warning/Caution OFF', 'Tooltip Warning/Caution ON'], desc: 'A warning/caution when buying if it will put the bank under the amount needed for max "Lucky!"/"Lucky!" (Frenzy) rewards', toggle: true, func: function() {CM.Disp.ToggleToolWarnCaut();}};
|
||||||
CM.ConfigData.ToolWarnCautPos = {label: ['Tooltip Warning/Caution Position (Left)', 'Tooltip Warning/Caution Position (Bottom)'], desc: 'Placement of the warning/caution boxes', toggle: false, func: function() {CM.Disp.ToggleToolWarnCautPos();}};
|
CM.ConfigData.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();}};
|
||||||
|
|||||||
100
src/Disp.js
100
src/Disp.js
@@ -55,7 +55,7 @@ CM.Disp.FormatTime = function(time, format) {
|
|||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
CM.Disp.GetTimeColor = function(price, bank, cps) {
|
CM.Disp.GetTimeColor = function(price, bank, cps, time) {
|
||||||
var color;
|
var color;
|
||||||
var text;
|
var text;
|
||||||
if (bank >= price) {
|
if (bank >= price) {
|
||||||
@@ -67,8 +67,13 @@ CM.Disp.GetTimeColor = function(price, bank, cps) {
|
|||||||
text = 'Done!';
|
text = 'Done!';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
if (typeof time !== 'undefined') {
|
||||||
|
var time = time;
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
var time = (price - bank) / cps;
|
var time = (price - bank) / cps;
|
||||||
|
}
|
||||||
text = CM.Disp.FormatTime(time);
|
text = CM.Disp.FormatTime(time);
|
||||||
if (time > 300) {
|
if (time > 300) {
|
||||||
color = CM.Disp.colorRed;
|
color = CM.Disp.colorRed;
|
||||||
@@ -148,7 +153,7 @@ CM.Disp.GetConfigDisplay = function(config) {
|
|||||||
CM.Disp.AddJscolor = function() {
|
CM.Disp.AddJscolor = function() {
|
||||||
CM.Disp.Jscolor = document.createElement('script');
|
CM.Disp.Jscolor = document.createElement('script');
|
||||||
CM.Disp.Jscolor.type = 'text/javascript';
|
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);
|
document.head.appendChild(CM.Disp.Jscolor);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -179,6 +184,9 @@ CM.Disp.CreateBotBar = function() {
|
|||||||
table.style.width = '100%';
|
table.style.width = '100%';
|
||||||
table.style.textAlign = 'center';
|
table.style.textAlign = 'center';
|
||||||
table.style.whiteSpace = 'nowrap';
|
table.style.whiteSpace = 'nowrap';
|
||||||
|
// TODO figure a better way
|
||||||
|
//table.style.tableLayout = 'fixed';
|
||||||
|
//table.style.overflow = 'hidden';
|
||||||
var tbody = document.createElement('tbody');
|
var tbody = document.createElement('tbody');
|
||||||
table.appendChild(tbody);
|
table.appendChild(tbody);
|
||||||
|
|
||||||
@@ -746,10 +754,10 @@ CM.Disp.CreateFavicon = function() {
|
|||||||
CM.Disp.UpdateFavicon = function() {
|
CM.Disp.UpdateFavicon = function() {
|
||||||
if (CM.Config.Favicon == 1 && CM.Disp.lastGoldenCookieState) {
|
if (CM.Config.Favicon == 1 && CM.Disp.lastGoldenCookieState) {
|
||||||
if (CM.Disp.goldenShimmer.wrath) {
|
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 {
|
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 {
|
else {
|
||||||
@@ -1274,8 +1282,8 @@ CM.Disp.AddMenuStats = function(title) {
|
|||||||
|
|
||||||
stats.appendChild(header('Prestige', 'Prestige'));
|
stats.appendChild(header('Prestige', 'Prestige'));
|
||||||
if (CM.Config.StatsPref.Prestige) {
|
if (CM.Config.StatsPref.Prestige) {
|
||||||
var possiblePresMax = Math.floor(Game.HowMuchPrestige(Game.cookiesEarned + Game.cookiesReset + CM.Cache.WrinkBank + (choEgg ? CM.Cache.lastChoEgg : 0)));
|
var possiblePresMax = Math.floor(Game.HowMuchPrestige(Game.cookiesEarned + Game.cookiesReset + CM.Cache.WrinkGodBank + (choEgg ? CM.Cache.lastChoEgg : 0)));
|
||||||
var neededCook = Game.HowManyCookiesReset(possiblePresMax + 1) - (Game.cookiesEarned + Game.cookiesReset + CM.Cache.WrinkBank + (choEgg ? CM.Cache.lastChoEgg : 0));
|
var neededCook = Game.HowManyCookiesReset(possiblePresMax + 1) - (Game.cookiesEarned + Game.cookiesReset + CM.Cache.WrinkGodBank + (choEgg ? CM.Cache.lastChoEgg : 0));
|
||||||
|
|
||||||
stats.appendChild(listing(listingQuest('Prestige Level (CUR / MAX)', 'PrestMaxTooltipPlaceholder'), document.createTextNode(Beautify(Game.prestige) + ' / ' + Beautify(possiblePresMax))));
|
stats.appendChild(listing(listingQuest('Prestige Level (CUR / MAX)', 'PrestMaxTooltipPlaceholder'), document.createTextNode(Beautify(Game.prestige) + ' / ' + Beautify(possiblePresMax))));
|
||||||
var cookiesNextFrag = document.createDocumentFragment();
|
var cookiesNextFrag = document.createDocumentFragment();
|
||||||
@@ -1514,6 +1522,15 @@ CM.Disp.ToggleToolWarnCautPos = function() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CM.Disp.CalculateGrimoireRefillTime = function(currentMagic, maxMagic, targetMagic) {
|
||||||
|
var count = 0;
|
||||||
|
while (currentMagic < targetMagic) {
|
||||||
|
currentMagic += Math.max(0.002, Math.pow(currentMagic / Math.max(maxMagic, 100), 0.5)) * 0.002;
|
||||||
|
count++;
|
||||||
|
}
|
||||||
|
return count / Game.fps;
|
||||||
|
}
|
||||||
|
|
||||||
CM.Disp.AddTooltipBuild = function() {
|
CM.Disp.AddTooltipBuild = function() {
|
||||||
CM.Disp.TooltipBuildBack = [];
|
CM.Disp.TooltipBuildBack = [];
|
||||||
for (var i in Game.Objects) {
|
for (var i in Game.Objects) {
|
||||||
@@ -1536,6 +1553,18 @@ CM.Disp.AddTooltipUpgrade = function() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CM.Disp.AddTooltipGrimoire = function() {
|
||||||
|
if (Game.Objects['Wizard tower'].minigameLoaded) {
|
||||||
|
CM.Disp.TooltipGrimoireBack = [];
|
||||||
|
for (var i in Game.Objects['Wizard tower'].minigame.spellsById) {
|
||||||
|
if (l('grimoireSpell' + i).onmouseover != null) {
|
||||||
|
CM.Disp.TooltipGrimoireBack[i] = l('grimoireSpell' + i).onmouseover;
|
||||||
|
eval('l(\'grimoireSpell\' + i).onmouseover = function() {Game.tooltip.dynamic = 1; Game.tooltip.draw(this, function() {return CM.Disp.Tooltip(\'g\', \'' + i + '\');}, \'this\'); Game.tooltip.wobble();}');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
CM.Disp.Tooltip = function(type, name) {
|
CM.Disp.Tooltip = function(type, name) {
|
||||||
if (type == 'b') {
|
if (type == 'b') {
|
||||||
l('tooltip').innerHTML = Game.Objects[name].tooltip();
|
l('tooltip').innerHTML = Game.Objects[name].tooltip();
|
||||||
@@ -1570,16 +1599,19 @@ CM.Disp.Tooltip = function(type, name) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else { // Upgrades
|
else if (type == 'u') {
|
||||||
if (!Game.UpgradesInStore[name]) return '';
|
if (!Game.UpgradesInStore[name]) return '';
|
||||||
l('tooltip').innerHTML = Game.crate(Game.UpgradesInStore[name], 'store', undefined, undefined, 1)();
|
l('tooltip').innerHTML = Game.crate(Game.UpgradesInStore[name], 'store', undefined, undefined, 1)();
|
||||||
}
|
}
|
||||||
|
else { // Grimoire
|
||||||
|
l('tooltip').innerHTML = Game.Objects['Wizard tower'].minigame.spellTooltip(name)();
|
||||||
|
}
|
||||||
|
|
||||||
var area = document.createElement('div');
|
var area = document.createElement('div');
|
||||||
area.id = 'CMTooltipArea';
|
area.id = 'CMTooltipArea';
|
||||||
l('tooltip').appendChild(area);
|
l('tooltip').appendChild(area);
|
||||||
|
|
||||||
if (CM.Config.Tooltip == 1 && (type != 'b' || Game.buyMode == 1)) {
|
if (CM.Config.Tooltip == 1 && (type == 'u' || (type == 'b' && Game.buyMode == 1))) {
|
||||||
l('tooltip').firstChild.style.paddingBottom = '4px';
|
l('tooltip').firstChild.style.paddingBottom = '4px';
|
||||||
var tooltip = document.createElement('div');
|
var tooltip = document.createElement('div');
|
||||||
tooltip.style.border = '1px solid';
|
tooltip.style.border = '1px solid';
|
||||||
@@ -1594,6 +1626,7 @@ CM.Disp.Tooltip = function(type, name) {
|
|||||||
div.textContent = text;
|
div.textContent = text;
|
||||||
return div;
|
return div;
|
||||||
}
|
}
|
||||||
|
|
||||||
tooltip.appendChild(header('Bonus Income'));
|
tooltip.appendChild(header('Bonus Income'));
|
||||||
var income = document.createElement('div');
|
var income = document.createElement('div');
|
||||||
income.style.marginBottom = '4px';
|
income.style.marginBottom = '4px';
|
||||||
@@ -1610,7 +1643,7 @@ CM.Disp.Tooltip = function(type, name) {
|
|||||||
time.id = 'CMTooltipTime';
|
time.id = 'CMTooltipTime';
|
||||||
tooltip.appendChild(time);
|
tooltip.appendChild(time);
|
||||||
|
|
||||||
l('tooltip').appendChild(tooltip);
|
area.appendChild(tooltip);
|
||||||
}
|
}
|
||||||
|
|
||||||
CM.Disp.tooltipType = type;
|
CM.Disp.tooltipType = type;
|
||||||
@@ -1624,6 +1657,7 @@ CM.Disp.Tooltip = function(type, name) {
|
|||||||
CM.Disp.UpdateTooltip = function() {
|
CM.Disp.UpdateTooltip = function() {
|
||||||
if (l('tooltipAnchor').style.display != 'none' && l('CMTooltipArea') != null) {
|
if (l('tooltipAnchor').style.display != 'none' && l('CMTooltipArea') != null) {
|
||||||
|
|
||||||
|
if (CM.Disp.tooltipType == 'b' || CM.Disp.tooltipType == 'u') {
|
||||||
// Error checking
|
// 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')) {
|
if (CM.Disp.tooltipType == 'u' && (typeof Game.UpgradesInStore[CM.Disp.tooltipName] === 'undefined' || typeof CM.Cache.Upgrades[Game.UpgradesInStore[CM.Disp.tooltipName].name] === 'undefined')) {
|
||||||
return;
|
return;
|
||||||
@@ -1713,6 +1747,54 @@ CM.Disp.UpdateTooltip = function() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else { // Grimoire
|
||||||
|
l('CMDispTooltipWarn').style.display = 'none';
|
||||||
|
l('CMDispTooltipCaut').style.display = 'none';
|
||||||
|
|
||||||
|
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';
|
||||||
|
tooltip.style.padding = '4px';
|
||||||
|
tooltip.style.margin = '0px -4px';
|
||||||
|
tooltip.id = 'CMTooltipBorder';
|
||||||
|
tooltip.className = CM.Disp.colorTextPre + CM.Disp.colorGray;
|
||||||
|
|
||||||
|
var header = function(text) {
|
||||||
|
var div = document.createElement('div');
|
||||||
|
div.style.fontWeight = 'bold';
|
||||||
|
div.className = CM.Disp.colorTextPre + CM.Disp.colorBlue;
|
||||||
|
div.textContent = text;
|
||||||
|
return div;
|
||||||
|
}
|
||||||
|
|
||||||
|
tooltip.appendChild(header('Time Left'));
|
||||||
|
var time = document.createElement('div');
|
||||||
|
time.id = 'CMTooltipTime';
|
||||||
|
tooltip.appendChild(time);
|
||||||
|
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');
|
||||||
|
recover.id = 'CMTooltipRecover';
|
||||||
|
tooltip.appendChild(recover);
|
||||||
|
var recoverColor = CM.Disp.GetTimeColor(minigame.magic, Math.max(0, minigame.magic - spellCost), undefined, CM.Disp.CalculateGrimoireRefillTime(Math.max(0, minigame.magic - spellCost), minigame.magicM, minigame.magic));
|
||||||
|
recover.textContent = recoverColor.text;
|
||||||
|
recover.className = CM.Disp.colorTextPre + recoverColor.color;
|
||||||
|
}
|
||||||
|
|
||||||
|
l('CMTooltipArea').appendChild(tooltip);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CM.Disp.DrawTooltipWarnCaut = function() {
|
CM.Disp.DrawTooltipWarnCaut = function() {
|
||||||
|
|||||||
67
src/Main.js
67
src/Main.js
@@ -10,7 +10,7 @@ CM.ReplaceNative = function() {
|
|||||||
Game.CalculateGains = function() {
|
Game.CalculateGains = function() {
|
||||||
CM.Backup.CalculateGains();
|
CM.Backup.CalculateGains();
|
||||||
CM.Sim.DoSims = 1;
|
CM.Sim.DoSims = 1;
|
||||||
CM.Sim.Date = new Date().getTime();
|
CM.Sim.Date = Date.now();
|
||||||
}
|
}
|
||||||
|
|
||||||
CM.Backup.tooltip = {};
|
CM.Backup.tooltip = {};
|
||||||
@@ -22,7 +22,7 @@ CM.ReplaceNative = function() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
CM.Backup.tooltip.update = Game.tooltip.update;
|
CM.Backup.tooltip.update = Game.tooltip.update;
|
||||||
eval('CM.Backup.tooltip.updateMod = ' + Game.tooltip.update.toString().split('this').join('Game.tooltip'));
|
eval('CM.Backup.tooltip.updateMod = ' + Game.tooltip.update.toString().split('this.').join('Game.tooltip.'));
|
||||||
Game.tooltip.update = function() {
|
Game.tooltip.update = function() {
|
||||||
CM.Backup.tooltip.updateMod();
|
CM.Backup.tooltip.updateMod();
|
||||||
CM.Disp.UpdateTooltipWarnCaut();
|
CM.Disp.UpdateTooltipWarnCaut();
|
||||||
@@ -42,6 +42,14 @@ CM.ReplaceNative = function() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Probably better to load per minigame
|
||||||
|
CM.Backup.scriptLoaded = Game.scriptLoaded;
|
||||||
|
Game.scriptLoaded = function(who, script) {
|
||||||
|
CM.Backup.scriptLoaded(who, script);
|
||||||
|
CM.Disp.AddTooltipGrimoire()
|
||||||
|
CM.ReplaceNativeGrimoire();
|
||||||
|
}
|
||||||
|
|
||||||
CM.Backup.RebuildUpgrades = Game.RebuildUpgrades;
|
CM.Backup.RebuildUpgrades = Game.RebuildUpgrades;
|
||||||
Game.RebuildUpgrades = function() {
|
Game.RebuildUpgrades = function() {
|
||||||
CM.Backup.RebuildUpgrades();
|
CM.Backup.RebuildUpgrades();
|
||||||
@@ -79,6 +87,40 @@ CM.ReplaceNative = function() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CM.ReplaceNativeGrimoire = function() {
|
||||||
|
CM.ReplaceNativeGrimoireLaunch();
|
||||||
|
CM.ReplaceNativeGrimoireDraw();
|
||||||
|
}
|
||||||
|
|
||||||
|
CM.ReplaceNativeGrimoireLaunch = function() {
|
||||||
|
if (!CM.HasReplaceNativeGrimoireLaunch && Game.Objects['Wizard tower'].minigameLoaded) {
|
||||||
|
var minigame = Game.Objects['Wizard tower'].minigame;
|
||||||
|
CM.Backup.GrimoireLaunch = minigame.launch;
|
||||||
|
eval('CM.Backup.GrimoireLaunchMod = ' + minigame.launch.toString().split('=this').join('= Game.Objects[\'Wizard tower\'].minigame'));
|
||||||
|
Game.Objects['Wizard tower'].minigame.launch = function() {
|
||||||
|
CM.Backup.GrimoireLaunchMod();
|
||||||
|
CM.Disp.AddTooltipGrimoire();
|
||||||
|
CM.HasReplaceNativeGrimoireDraw = false;
|
||||||
|
CM.ReplaceNativeGrimoireDraw();
|
||||||
|
}
|
||||||
|
CM.HasReplaceNativeGrimoireLaunch = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CM.ReplaceNativeGrimoireDraw = function() {
|
||||||
|
if (!CM.HasReplaceNativeGrimoireDraw && Game.Objects['Wizard tower'].minigameLoaded) {
|
||||||
|
var minigame = Game.Objects['Wizard tower'].minigame;
|
||||||
|
CM.Backup.GrimoireDraw = minigame.draw;
|
||||||
|
Game.Objects['Wizard tower'].minigame.draw = function() {
|
||||||
|
CM.Backup.GrimoireDraw();
|
||||||
|
if (minigame.magic < minigame.magicM) {
|
||||||
|
minigame.magicBarTextL.innerHTML += ' (' + CM.Disp.FormatTime(CM.Disp.CalculateGrimoireRefillTime(minigame.magic, minigame.magicM, minigame.magicM)) + ')';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
CM.HasReplaceNativeGrimoireDraw = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
CM.Loop = function() {
|
CM.Loop = function() {
|
||||||
if (CM.Disp.lastAscendState != Game.OnAscend) {
|
if (CM.Disp.lastAscendState != Game.OnAscend) {
|
||||||
CM.Disp.lastAscendState = Game.OnAscend;
|
CM.Disp.lastAscendState = Game.OnAscend;
|
||||||
@@ -178,16 +220,18 @@ CM.DelayInit = function() {
|
|||||||
CM.Disp.CreateFavicon();
|
CM.Disp.CreateFavicon();
|
||||||
CM.Disp.CreateGCTimer();
|
CM.Disp.CreateGCTimer();
|
||||||
CM.Disp.CreateTooltip('GoldCookTooltipPlaceholder', 'Calculated with Golden Switch off', '200px');
|
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, selling all buildings with Earth Shatterer aura, and buying Chocolate egg', '310px');
|
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', 'Not calculated with cookies gained from wrinklers or Chocolate egg', '200px');
|
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, selling all buildings with Earth Shatterer aura, and buying Chocolate egg', '310px');
|
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 at 100% of its potential and from reset achievements if you have the same buildings/upgrades after reset', '340px');
|
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, selling all buildings with Earth Shatterer aura, and then buying Chocolate egg', '300px');
|
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.CreateTooltipWarnCaut();
|
||||||
CM.Disp.AddTooltipBuild();
|
CM.Disp.AddTooltipBuild();
|
||||||
|
CM.Disp.AddTooltipGrimoire();
|
||||||
CM.Disp.AddWrinklerAreaDetect();
|
CM.Disp.AddWrinklerAreaDetect();
|
||||||
CM.Cache.InitCookiesDiff();
|
CM.Cache.InitCookiesDiff();
|
||||||
CM.ReplaceNative();
|
CM.ReplaceNative();
|
||||||
|
CM.ReplaceNativeGrimoire();
|
||||||
Game.CalculateGains();
|
Game.CalculateGains();
|
||||||
CM.LoadConfig(); // Must be after all things are created!
|
CM.LoadConfig(); // Must be after all things are created!
|
||||||
CM.Disp.lastAscendState = Game.OnAscend;
|
CM.Disp.lastAscendState = Game.OnAscend;
|
||||||
@@ -200,9 +244,12 @@ CM.DelayInit = function() {
|
|||||||
Game.Win('Third-party');
|
Game.Win('Third-party');
|
||||||
}
|
}
|
||||||
|
|
||||||
CM.ConfigDefault = {BotBar: 1, TimerBar: 1, TimerBarPos: 0, BuildColor: 1, BulkBuildColor: 0, UpBarColor: 1, CalcWrink: 1, CPSMode: 1, AvgCPSHist: 2, AvgClicksHist: 2, 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.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: '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.ConfigPrefix = 'CMConfig';
|
||||||
|
|
||||||
CM.VersionMajor = '2.0034';
|
CM.VersionMajor = '2.0045';
|
||||||
CM.VersionMinor = '2';
|
CM.VersionMinor = '1';
|
||||||
|
|
||||||
|
|||||||
71
src/Sim.js
71
src/Sim.js
@@ -76,7 +76,7 @@ CM.Sim.Win = function(what) {
|
|||||||
|
|
||||||
eval('CM.Sim.HasAchiev = ' + Game.HasAchiev.toString().split('Game').join('CM.Sim'));
|
eval('CM.Sim.HasAchiev = ' + Game.HasAchiev.toString().split('Game').join('CM.Sim'));
|
||||||
|
|
||||||
eval('CM.Sim.GetHeavenlyMultiplier = ' + Game.GetHeavenlyMultiplier.toString().split('Game').join('CM.Sim'));
|
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) {
|
CM.Sim.hasAura = function(what) {
|
||||||
if (Game.dragonAuras[CM.Sim.dragonAura].name == what || Game.dragonAuras[CM.Sim.dragonAura2].name == what)
|
if (Game.dragonAuras[CM.Sim.dragonAura].name == what || Game.dragonAuras[CM.Sim.dragonAura2].name == what)
|
||||||
@@ -128,7 +128,7 @@ CM.Sim.CopyData = function() {
|
|||||||
CM.Sim.UpgradesOwned = Game.UpgradesOwned;
|
CM.Sim.UpgradesOwned = Game.UpgradesOwned;
|
||||||
CM.Sim.pledges = Game.pledges;
|
CM.Sim.pledges = Game.pledges;
|
||||||
CM.Sim.AchievementsOwned = Game.AchievementsOwned;
|
CM.Sim.AchievementsOwned = Game.AchievementsOwned;
|
||||||
CM.Sim.heavenlyPower = Game.heavenlyPower;
|
CM.Sim.heavenlyPower = Game.heavenlyPower; // Unneeded?
|
||||||
CM.Sim.prestige = Game.prestige;
|
CM.Sim.prestige = Game.prestige;
|
||||||
CM.Sim.dragonAura = Game.dragonAura;
|
CM.Sim.dragonAura = Game.dragonAura;
|
||||||
CM.Sim.dragonAura2 = Game.dragonAura2;
|
CM.Sim.dragonAura2 = Game.dragonAura2;
|
||||||
@@ -240,6 +240,8 @@ CM.Sim.CalculateGains = function() {
|
|||||||
if (CM.Sim.Has('Kitten accountants')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult);
|
if (CM.Sim.Has('Kitten accountants')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult);
|
||||||
if (CM.Sim.Has('Kitten specialists')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.2 * milkMult);
|
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 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 angels')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.1 * milkMult);
|
if (CM.Sim.Has('Kitten angels')) mult *= (1 + (CM.Sim.AchievementsOwned / 25) * 0.1 * milkMult);
|
||||||
|
|
||||||
var eggMult = 1;
|
var eggMult = 1;
|
||||||
@@ -264,9 +266,20 @@ CM.Sim.CalculateGains = function() {
|
|||||||
}
|
}
|
||||||
mult *= eggMult;
|
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 (CM.Sim.hasAura('Radiant Appetite')) mult *= 2;
|
||||||
|
|
||||||
|
if (Game.hasAura('Dragon\'s Fortune')) {
|
||||||
|
var n = Game.shimmerTypes['golden'].n;
|
||||||
|
for (var i = 0; i < n; i++) {
|
||||||
|
mult *= 2.11;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
var rawCookiesPs = CM.Sim.cookiesPs * mult;
|
var rawCookiesPs = CM.Sim.cookiesPs * mult;
|
||||||
|
|
||||||
for (var i in Game.CpsAchievements) {
|
for (var i in Game.CpsAchievements) {
|
||||||
if (rawCookiesPs >= Game.CpsAchievements[i].threshold) CM.Sim.Win(Game.CpsAchievements[i].name);
|
if (rawCookiesPs >= Game.CpsAchievements[i].threshold) CM.Sim.Win(Game.CpsAchievements[i].name);
|
||||||
}
|
}
|
||||||
@@ -298,7 +311,7 @@ CM.Sim.CalculateGains = function() {
|
|||||||
};
|
};
|
||||||
|
|
||||||
CM.Sim.CheckOtherAchiev = function() {
|
CM.Sim.CheckOtherAchiev = function() {
|
||||||
var grandmas=0;
|
var grandmas = 0;
|
||||||
if (CM.Sim.Has('Farmer grandmas')) grandmas++;
|
if (CM.Sim.Has('Farmer grandmas')) grandmas++;
|
||||||
if (CM.Sim.Has('Worker grandmas')) grandmas++;
|
if (CM.Sim.Has('Worker grandmas')) grandmas++;
|
||||||
if (CM.Sim.Has('Miner grandmas')) grandmas++;
|
if (CM.Sim.Has('Miner grandmas')) grandmas++;
|
||||||
@@ -311,6 +324,7 @@ CM.Sim.CheckOtherAchiev = function() {
|
|||||||
if (CM.Sim.Has('Banker grandmas')) grandmas++;
|
if (CM.Sim.Has('Banker grandmas')) grandmas++;
|
||||||
if (CM.Sim.Has('Priestess grandmas')) grandmas++;
|
if (CM.Sim.Has('Priestess grandmas')) grandmas++;
|
||||||
if (CM.Sim.Has('Witch grandmas')) grandmas++;
|
if (CM.Sim.Has('Witch grandmas')) grandmas++;
|
||||||
|
if (CM.Sim.Has('Lucky grandmas')) grandmas++;
|
||||||
if (!CM.Sim.HasAchiev('Elder') && grandmas >= 7) CM.Sim.Win('Elder');
|
if (!CM.Sim.HasAchiev('Elder') && grandmas >= 7) CM.Sim.Win('Elder');
|
||||||
|
|
||||||
var buildingsOwned = 0;
|
var buildingsOwned = 0;
|
||||||
@@ -460,45 +474,22 @@ CM.Sim.ResetBonus = function(possiblePresMax) {
|
|||||||
|
|
||||||
// Calculate CPS with all Heavenly upgrades
|
// Calculate CPS with all Heavenly upgrades
|
||||||
var curCPS = Game.cookiesPs;
|
var curCPS = Game.cookiesPs;
|
||||||
if (CM.Sim.Upgrades['Heavenly chip secret'].bought == 0 || CM.Sim.Upgrades['Heavenly cookie stand'].bought == 0 || CM.Sim.Upgrades['Heavenly bakery'].bought == 0 || CM.Sim.Upgrades['Heavenly confectionery'].bought == 0 || CM.Sim.Upgrades['Heavenly key'].bought == 0) {
|
|
||||||
CM.Sim.CopyData();
|
CM.Sim.CopyData();
|
||||||
|
|
||||||
if (CM.Sim.Upgrades['Heavenly chip secret'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly chip secret'].bought = 1;
|
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly cookie stand'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly cookie stand'].bought = 1;
|
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly bakery'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly bakery'].bought = 1;
|
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly confectionery'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly confectionery'].bought = 1;
|
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly key'].bought == 0) {
|
if (CM.Sim.Upgrades['Heavenly key'].bought == 0) {
|
||||||
|
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.Upgrades['Heavenly key'].bought = 1;
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
CM.Sim.Win('Wholesome');
|
|
||||||
}
|
|
||||||
|
|
||||||
lastAchievementsOwned = CM.Sim.AchievementsOwned;
|
|
||||||
|
|
||||||
CM.Sim.CalculateGains();
|
CM.Sim.CalculateGains();
|
||||||
|
|
||||||
CM.Sim.CheckOtherAchiev();
|
|
||||||
|
|
||||||
if (lastAchievementsOwned != CM.Sim.AchievementsOwned) {
|
|
||||||
CM.Sim.CalculateGains();
|
|
||||||
}
|
|
||||||
|
|
||||||
curCPS = CM.Sim.cookiesPs;
|
curCPS = CM.Sim.cookiesPs;
|
||||||
}
|
|
||||||
|
|
||||||
CM.Sim.CopyData();
|
CM.Sim.CopyData();
|
||||||
|
}
|
||||||
|
|
||||||
if (Game.cookiesEarned >= 1000000) CM.Sim.Win('Sacrifice');
|
if (Game.cookiesEarned >= 1000000) CM.Sim.Win('Sacrifice');
|
||||||
if (Game.cookiesEarned >= 1000000000) CM.Sim.Win('Oblivion');
|
if (Game.cookiesEarned >= 1000000000) CM.Sim.Win('Oblivion');
|
||||||
@@ -511,27 +502,11 @@ CM.Sim.ResetBonus = function(possiblePresMax) {
|
|||||||
if (Game.cookiesEarned >= 1000000000000000000000000000000) CM.Sim.Win('Negative void');
|
if (Game.cookiesEarned >= 1000000000000000000000000000000) CM.Sim.Win('Negative void');
|
||||||
if (Game.cookiesEarned >= 1000000000000000000000000000000000) CM.Sim.Win('To crumbs, you say?');
|
if (Game.cookiesEarned >= 1000000000000000000000000000000000) CM.Sim.Win('To crumbs, you say?');
|
||||||
|
|
||||||
if (CM.Sim.Upgrades['Heavenly chip secret'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly chip secret'].bought = 1;
|
CM.Sim.Upgrades['Heavenly chip secret'].bought = 1;
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly cookie stand'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly cookie stand'].bought = 1;
|
CM.Sim.Upgrades['Heavenly cookie stand'].bought = 1;
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly bakery'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly bakery'].bought = 1;
|
CM.Sim.Upgrades['Heavenly bakery'].bought = 1;
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly confectionery'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly confectionery'].bought = 1;
|
CM.Sim.Upgrades['Heavenly confectionery'].bought = 1;
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
}
|
|
||||||
if (CM.Sim.Upgrades['Heavenly key'].bought == 0) {
|
|
||||||
CM.Sim.Upgrades['Heavenly key'].bought = 1;
|
CM.Sim.Upgrades['Heavenly key'].bought = 1;
|
||||||
CM.Sim.UpgradesOwned++;
|
|
||||||
CM.Sim.Win('Wholesome');
|
|
||||||
}
|
|
||||||
|
|
||||||
CM.Sim.prestige = possiblePresMax;
|
CM.Sim.prestige = possiblePresMax;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user