cookie clicker but bigger
Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.
 
 
 
 

178 linhas
4.4 KiB

  1. "use strict";
  2. let belongings = {};
  3. let ownedUpgrades = [];
  4. let resources = {
  5. "food": 0
  6. };
  7. let updateRate = 60;
  8. function calculateProductivity() {
  9. let productivity = 0;
  10. for (const [key, value] of Object.entries(belongings)) {
  11. productivity += productivityOf(key);
  12. }
  13. return productivity;
  14. }
  15. // here's where upgrades will go :3
  16. function productivityOf(type) {
  17. let baseProd = buildings[type].prod;
  18. return baseProd * belongings[type].count;
  19. }
  20. function costOf(type) {
  21. let baseCost = buildings[type].cost
  22. let countCost = baseCost * Math.pow(1.15, belongings[type].count);
  23. return Math.round(countCost);
  24. }
  25. function buyBuilding(type) {
  26. let cost = costOf(type);
  27. if (resources.food > cost) {
  28. belongings[type].count += 1;
  29. resources.food -= cost;
  30. }
  31. }
  32. // update stuff
  33. function updateResources() {
  34. addResources();
  35. displayResources();
  36. displayBuildings();
  37. setTimeout(updateResources, 1000/updateRate);
  38. }
  39. function addResources() {
  40. resources.food += calculateProductivity() * 1 / updateRate;
  41. }
  42. function displayResources() {
  43. document.getElementById("resource-food").innerText = "Food: " + render(resources.food);
  44. }
  45. function displayBuildings() {
  46. for (const [key, value] of Object.entries(belongings)) {
  47. document.querySelector("#building-" + key + " > .building-button-name").innerText = value.count + " " + buildings[key].name + (value.count == 1 ? "" : "s");
  48. document.querySelector("#building-" + key + " > .building-button-cost").innerText = costOf(key) + " food";
  49. }
  50. }
  51. function eatMicro() {
  52. resources.food += 1;
  53. }
  54. // setup stuff lol
  55. // we'll initialize the dict of buildings we can own
  56. function setup() {
  57. initializeData();
  58. createButtons();
  59. registerListeners();
  60. console.log(belongings)
  61. }
  62. function initializeData() {
  63. for (const [key, value] of Object.entries(buildings)) {
  64. belongings[key] = {};
  65. belongings[key].count = 0;
  66. }
  67. }
  68. function registerListeners() {
  69. document.querySelectorAll(".building-button").forEach(function(button) {
  70. let id = button.id.replace("building-", "");
  71. button.addEventListener("click", function() { buyBuilding(id); });
  72. });
  73. document.querySelector("#tasty-micro").addEventListener("click", eatMicro);
  74. }
  75. function createButtons() {
  76. createBuildings();
  77. createUpgrades();
  78. }
  79. function createBuildings() {
  80. let container = document.querySelector("#buildings-area");
  81. for (const [key, value] of Object.entries(buildings)) {
  82. let button = document.createElement("div");
  83. button.classList.add("building-button");
  84. button.id = "building-" + key;
  85. let buttonName = document.createElement("div");
  86. buttonName.classList.add("building-button-name");
  87. let buttonCost = document.createElement("div");
  88. buttonCost.classList.add("building-button-cost");
  89. button.appendChild(buttonName);
  90. button.appendChild(buttonCost);
  91. container.appendChild(button);
  92. }
  93. }
  94. function upgradeTooltip(id, event) {
  95. console.log(upgrades[id].desc);
  96. console.log(event.clientX, event.clientY);
  97. let tooltip = document.querySelector("#upgrade-tooltip");
  98. tooltip.style.setProperty("display", "block");
  99. let tooltipDesc = document.querySelector("#upgrade-tooltip-desc");
  100. tooltipDesc.innerText = upgrades[id].desc;
  101. let tooltipEffect = document.querySelector("#upgrade-tooltip-effect");
  102. tooltipEffect.innerText = upgrade_types[upgrades[id].effect.type].desc(buildings[upgrades[id].effect.target].name);
  103. let yOffset = tooltip.parentElement.getBoundingClientRect().y;
  104. let yTrans = Math.round(event.clientY - yOffset);
  105. tooltip.style.setProperty("transform", "translate(-220px, " + yTrans + "px)");
  106. }
  107. function upgradeTooltipRemove() {
  108. let tooltip = document.querySelector("#upgrade-tooltip");
  109. tooltip.style.setProperty("display", "none");
  110. }
  111. function createUpgrades() {
  112. let container = document.querySelector("#upgrades-list");
  113. for (const [key, value] of Object.entries(upgrades)) {
  114. let button = document.createElement("div");
  115. button.classList.add("upgrade-button");
  116. button.id = "building-" + key;
  117. let buttonName = document.createElement("div");
  118. buttonName.classList.add("upgrade-button-name");
  119. buttonName.innerText = value.name;
  120. button.appendChild(buttonName);
  121. button.addEventListener("mousemove", function(e) { upgradeTooltip(key, event); });
  122. button.addEventListener("mouseleave", function() { upgradeTooltipRemove(); });
  123. container.appendChild(button);
  124. }
  125. }
  126. window.onload = function() {
  127. setup();
  128. setTimeout(updateResources, 1000/updateRate);
  129. }