@firestone-hs/simulate-bgs-battle 1.1.565 → 1.1.567

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (468) hide show
  1. package/dist/bgs-player-entity.d.ts +2 -0
  2. package/dist/bgs-player-entity.js.map +1 -1
  3. package/dist/cards/card.interface.d.ts +32 -6
  4. package/dist/cards/card.interface.js +13 -1
  5. package/dist/cards/card.interface.js.map +1 -1
  6. package/dist/cards/cards-data.d.ts +1 -0
  7. package/dist/cards/cards-data.js +8 -0
  8. package/dist/cards/cards-data.js.map +1 -1
  9. package/dist/cards/impl/_card-mappings.js +124 -0
  10. package/dist/cards/impl/_card-mappings.js.map +1 -1
  11. package/dist/cards/impl/bg-spell/sharing-is-caring.js +1 -1
  12. package/dist/cards/impl/bg-spell/sharing-is-caring.js.map +1 -1
  13. package/dist/cards/impl/hero-power/all-will-burn.js +2 -4
  14. package/dist/cards/impl/hero-power/all-will-burn.js.map +1 -1
  15. package/dist/cards/impl/hero-power/fragrant-phylactery.js +1 -2
  16. package/dist/cards/impl/hero-power/fragrant-phylactery.js.map +1 -1
  17. package/dist/cards/impl/hero-power/wax-warband.d.ts +3 -0
  18. package/dist/cards/impl/hero-power/wax-warband.js +4 -4
  19. package/dist/cards/impl/hero-power/wax-warband.js.map +1 -1
  20. package/dist/cards/impl/minion/admiral-eliza-goreblade.js +1 -2
  21. package/dist/cards/impl/minion/admiral-eliza-goreblade.js.map +1 -1
  22. package/dist/cards/impl/minion/alleycat.d.ts +2 -0
  23. package/dist/cards/impl/minion/alleycat.js +24 -0
  24. package/dist/cards/impl/minion/alleycat.js.map +1 -0
  25. package/dist/cards/impl/minion/amber-guardian.js +1 -2
  26. package/dist/cards/impl/minion/amber-guardian.js.map +1 -1
  27. package/dist/cards/impl/minion/amplifying-lightspawn.d.ts +2 -0
  28. package/dist/cards/impl/minion/amplifying-lightspawn.js +13 -0
  29. package/dist/cards/impl/minion/amplifying-lightspawn.js.map +1 -0
  30. package/dist/cards/impl/minion/apprentice-of-sefin.d.ts +6 -0
  31. package/dist/cards/impl/minion/apprentice-of-sefin.js +78 -0
  32. package/dist/cards/impl/minion/apprentice-of-sefin.js.map +1 -0
  33. package/dist/cards/impl/minion/ashen-corruptor.d.ts +2 -0
  34. package/dist/cards/impl/minion/ashen-corruptor.js +10 -0
  35. package/dist/cards/impl/minion/ashen-corruptor.js.map +1 -0
  36. package/dist/cards/impl/minion/assistant-guard.js +2 -1
  37. package/dist/cards/impl/minion/assistant-guard.js.map +1 -1
  38. package/dist/cards/impl/minion/auto-assembler-enchantment.d.ts +2 -0
  39. package/dist/cards/impl/minion/auto-assembler-enchantment.js +17 -0
  40. package/dist/cards/impl/minion/auto-assembler-enchantment.js.map +1 -0
  41. package/dist/cards/impl/minion/auto-assembler.d.ts +2 -0
  42. package/dist/cards/impl/minion/auto-assembler.js +14 -0
  43. package/dist/cards/impl/minion/auto-assembler.js.map +1 -0
  44. package/dist/cards/impl/minion/battlecruiser.js +2 -3
  45. package/dist/cards/impl/minion/battlecruiser.js.map +1 -1
  46. package/dist/cards/impl/minion/beetle.js +1 -1
  47. package/dist/cards/impl/minion/beetle.js.map +1 -1
  48. package/dist/cards/impl/minion/bellowing-tyrant.js +2 -2
  49. package/dist/cards/impl/minion/bellowing-tyrant.js.map +1 -1
  50. package/dist/cards/impl/minion/blazing-skyfin.js +1 -1
  51. package/dist/cards/impl/minion/blazing-skyfin.js.map +1 -1
  52. package/dist/cards/impl/minion/bonker.d.ts +2 -0
  53. package/dist/cards/impl/minion/bonker.js +18 -0
  54. package/dist/cards/impl/minion/bonker.js.map +1 -0
  55. package/dist/cards/impl/minion/bronze-steward.d.ts +2 -0
  56. package/dist/cards/impl/minion/bronze-steward.js +29 -0
  57. package/dist/cards/impl/minion/bronze-steward.js.map +1 -0
  58. package/dist/cards/impl/minion/bubble-gunner.js +3 -34
  59. package/dist/cards/impl/minion/bubble-gunner.js.map +1 -1
  60. package/dist/cards/impl/minion/carrier.js +1 -1
  61. package/dist/cards/impl/minion/carrier.js.map +1 -1
  62. package/dist/cards/impl/minion/choral-mrrrglr.js +1 -2
  63. package/dist/cards/impl/minion/choral-mrrrglr.js.map +1 -1
  64. package/dist/cards/impl/minion/clunker-junker.js +2 -1
  65. package/dist/cards/impl/minion/clunker-junker.js.map +1 -1
  66. package/dist/cards/impl/minion/coilskar-sapper.d.ts +2 -0
  67. package/dist/cards/impl/minion/coilskar-sapper.js +13 -0
  68. package/dist/cards/impl/minion/coilskar-sapper.js.map +1 -0
  69. package/dist/cards/impl/minion/corrupted-bristler.d.ts +2 -0
  70. package/dist/cards/impl/minion/corrupted-bristler.js +32 -0
  71. package/dist/cards/impl/minion/corrupted-bristler.js.map +1 -0
  72. package/dist/cards/impl/minion/corrupted-myrmidon.js +1 -2
  73. package/dist/cards/impl/minion/corrupted-myrmidon.js.map +1 -1
  74. package/dist/cards/impl/minion/crabby.js +1 -2
  75. package/dist/cards/impl/minion/crabby.js.map +1 -1
  76. package/dist/cards/impl/minion/dastardly-drust.d.ts +2 -0
  77. package/dist/cards/impl/minion/dastardly-drust.js +20 -0
  78. package/dist/cards/impl/minion/dastardly-drust.js.map +1 -0
  79. package/dist/cards/impl/minion/deadstomper.js +1 -2
  80. package/dist/cards/impl/minion/deadstomper.js.map +1 -1
  81. package/dist/cards/impl/minion/deflecto-bot.js +1 -2
  82. package/dist/cards/impl/minion/deflecto-bot.js.map +1 -1
  83. package/dist/cards/impl/minion/diremuck-forager.js +1 -2
  84. package/dist/cards/impl/minion/diremuck-forager.js.map +1 -1
  85. package/dist/cards/impl/minion/dreaming-thornweaver.d.ts +2 -0
  86. package/dist/cards/impl/minion/dreaming-thornweaver.js +17 -0
  87. package/dist/cards/impl/minion/dreaming-thornweaver.js.map +1 -0
  88. package/dist/cards/impl/minion/drustfallen-butcher.d.ts +2 -0
  89. package/dist/cards/impl/minion/drustfallen-butcher.js +14 -0
  90. package/dist/cards/impl/minion/drustfallen-butcher.js.map +1 -0
  91. package/dist/cards/impl/minion/echoing-roar.js +1 -2
  92. package/dist/cards/impl/minion/echoing-roar.js.map +1 -1
  93. package/dist/cards/impl/minion/efficient-engineer.js +6 -1
  94. package/dist/cards/impl/minion/efficient-engineer.js.map +1 -1
  95. package/dist/cards/impl/minion/elder-taggawag.js +1 -2
  96. package/dist/cards/impl/minion/elder-taggawag.js.map +1 -1
  97. package/dist/cards/impl/minion/electric-synthesizer.js +3 -2
  98. package/dist/cards/impl/minion/electric-synthesizer.js.map +1 -1
  99. package/dist/cards/impl/minion/elite-navigator.d.ts +2 -0
  100. package/dist/cards/impl/minion/elite-navigator.js +24 -0
  101. package/dist/cards/impl/minion/elite-navigator.js.map +1 -0
  102. package/dist/cards/impl/minion/fauna-whisperer.d.ts +2 -0
  103. package/dist/cards/impl/minion/fauna-whisperer.js +29 -0
  104. package/dist/cards/impl/minion/fauna-whisperer.js.map +1 -0
  105. package/dist/cards/impl/minion/fire-forged-evoker.d.ts +2 -0
  106. package/dist/cards/impl/minion/fire-forged-evoker.js +14 -0
  107. package/dist/cards/impl/minion/fire-forged-evoker.js.map +1 -0
  108. package/dist/cards/impl/minion/firescale-hoarder.d.ts +2 -0
  109. package/dist/cards/impl/minion/firescale-hoarder.js +19 -0
  110. package/dist/cards/impl/minion/firescale-hoarder.js.map +1 -0
  111. package/dist/cards/impl/minion/flighty-scout.d.ts +2 -0
  112. package/dist/cards/impl/minion/flighty-scout.js +24 -0
  113. package/dist/cards/impl/minion/flighty-scout.js.map +1 -0
  114. package/dist/cards/impl/minion/forest-rover.js +2 -1
  115. package/dist/cards/impl/minion/forest-rover.js.map +1 -1
  116. package/dist/cards/impl/minion/fountain-chiller.js +2 -2
  117. package/dist/cards/impl/minion/fountain-chiller.js.map +1 -1
  118. package/dist/cards/impl/minion/gem-smuggler.js +1 -0
  119. package/dist/cards/impl/minion/gem-smuggler.js.map +1 -1
  120. package/dist/cards/impl/minion/general-drakkisath.js +1 -0
  121. package/dist/cards/impl/minion/general-drakkisath.js.map +1 -1
  122. package/dist/cards/impl/minion/gentle-djinni.js +1 -0
  123. package/dist/cards/impl/minion/gentle-djinni.js.map +1 -1
  124. package/dist/cards/impl/minion/gentle-stag.js +7 -3
  125. package/dist/cards/impl/minion/gentle-stag.js.map +1 -1
  126. package/dist/cards/impl/minion/glowgullet-warlord.d.ts +2 -0
  127. package/dist/cards/impl/minion/glowgullet-warlord.js +15 -0
  128. package/dist/cards/impl/minion/glowgullet-warlord.js.map +1 -0
  129. package/dist/cards/impl/minion/glowing-cinder.d.ts +2 -0
  130. package/dist/cards/impl/minion/glowing-cinder.js +11 -0
  131. package/dist/cards/impl/minion/glowing-cinder.js.map +1 -0
  132. package/dist/cards/impl/minion/goldgrubber.d.ts +2 -0
  133. package/dist/cards/impl/minion/goldgrubber.js +16 -0
  134. package/dist/cards/impl/minion/goldgrubber.js.map +1 -0
  135. package/dist/cards/impl/minion/gormling-gourmet.d.ts +2 -0
  136. package/dist/cards/impl/minion/gormling-gourmet.js +19 -0
  137. package/dist/cards/impl/minion/gormling-gourmet.js.map +1 -0
  138. package/dist/cards/impl/minion/grease-bot.js +1 -2
  139. package/dist/cards/impl/minion/grease-bot.js.map +1 -1
  140. package/dist/cards/impl/minion/greenskeeper.d.ts +2 -0
  141. package/dist/cards/impl/minion/greenskeeper.js +18 -0
  142. package/dist/cards/impl/minion/greenskeeper.js.map +1 -0
  143. package/dist/cards/impl/minion/grimscale-elegist.d.ts +2 -0
  144. package/dist/cards/impl/minion/grimscale-elegist.js +20 -0
  145. package/dist/cards/impl/minion/grimscale-elegist.js.map +1 -0
  146. package/dist/cards/impl/minion/gritty-headhunter.js +1 -0
  147. package/dist/cards/impl/minion/gritty-headhunter.js.map +1 -1
  148. package/dist/cards/impl/minion/hackerfin.js +3 -2
  149. package/dist/cards/impl/minion/hackerfin.js.map +1 -1
  150. package/dist/cards/impl/minion/hawkstrider-herald.js +1 -1
  151. package/dist/cards/impl/minion/hawkstrider-herald.js.map +1 -1
  152. package/dist/cards/impl/minion/hoarding-hatespawn.js +1 -1
  153. package/dist/cards/impl/minion/hoarding-hatespawn.js.map +1 -1
  154. package/dist/cards/impl/minion/hungry-snapjaw.js +1 -1
  155. package/dist/cards/impl/minion/hungry-snapjaw.js.map +1 -1
  156. package/dist/cards/impl/minion/hydralisk.js +1 -1
  157. package/dist/cards/impl/minion/hydralisk.js.map +1 -1
  158. package/dist/cards/impl/minion/ignition-specialist.d.ts +2 -0
  159. package/dist/cards/impl/minion/ignition-specialist.js +16 -0
  160. package/dist/cards/impl/minion/ignition-specialist.js.map +1 -0
  161. package/dist/cards/impl/minion/immortal.js +1 -2
  162. package/dist/cards/impl/minion/immortal.js.map +1 -1
  163. package/dist/cards/impl/minion/implant-subject.js +1 -1
  164. package/dist/cards/impl/minion/implant-subject.js.map +1 -1
  165. package/dist/cards/impl/minion/imposing-percussionist.js +1 -0
  166. package/dist/cards/impl/minion/imposing-percussionist.js.map +1 -1
  167. package/dist/cards/impl/minion/impulsive-trickster.js +13 -1
  168. package/dist/cards/impl/minion/impulsive-trickster.js.map +1 -1
  169. package/dist/cards/impl/minion/inspiring-underdog.js +2 -2
  170. package/dist/cards/impl/minion/inspiring-underdog.js.map +1 -1
  171. package/dist/cards/impl/minion/irate-rooster.js +1 -1
  172. package/dist/cards/impl/minion/irate-rooster.js.map +1 -1
  173. package/dist/cards/impl/minion/king-bagurgle.js +4 -3
  174. package/dist/cards/impl/minion/king-bagurgle.js.map +1 -1
  175. package/dist/cards/impl/minion/lightfang-enforcer.js +1 -1
  176. package/dist/cards/impl/minion/lightfang-enforcer.js.map +1 -1
  177. package/dist/cards/impl/minion/lokholar-frostforger.d.ts +2 -0
  178. package/dist/cards/impl/minion/lokholar-frostforger.js +17 -0
  179. package/dist/cards/impl/minion/lokholar-frostforger.js.map +1 -0
  180. package/dist/cards/impl/minion/lovesick-balladist.js +6 -3
  181. package/dist/cards/impl/minion/lovesick-balladist.js.map +1 -1
  182. package/dist/cards/impl/minion/low-flier.js +1 -1
  183. package/dist/cards/impl/minion/low-flier.js.map +1 -1
  184. package/dist/cards/impl/minion/lurker.js +1 -1
  185. package/dist/cards/impl/minion/lurker.js.map +1 -1
  186. package/dist/cards/impl/minion/mantid-queen.js +1 -1
  187. package/dist/cards/impl/minion/mantid-queen.js.map +1 -1
  188. package/dist/cards/impl/minion/maw-caster.d.ts +2 -0
  189. package/dist/cards/impl/minion/maw-caster.js +25 -0
  190. package/dist/cards/impl/minion/maw-caster.js.map +1 -0
  191. package/dist/cards/impl/minion/mecha-jaraxxus.js +1 -0
  192. package/dist/cards/impl/minion/mecha-jaraxxus.js.map +1 -1
  193. package/dist/cards/impl/minion/mechagnome-interpreter.d.ts +2 -0
  194. package/dist/cards/impl/minion/mechagnome-interpreter.js +12 -0
  195. package/dist/cards/impl/minion/mechagnome-interpreter.js.map +1 -0
  196. package/dist/cards/impl/minion/menagerie-jug.js +1 -0
  197. package/dist/cards/impl/minion/menagerie-jug.js.map +1 -1
  198. package/dist/cards/impl/minion/metallic-hunter.d.ts +2 -0
  199. package/dist/cards/impl/minion/metallic-hunter.js +13 -0
  200. package/dist/cards/impl/minion/metallic-hunter.js.map +1 -0
  201. package/dist/cards/impl/minion/misfit-dragonling.js +1 -2
  202. package/dist/cards/impl/minion/misfit-dragonling.js.map +1 -1
  203. package/dist/cards/impl/minion/monstrous-macaw.d.ts +2 -0
  204. package/dist/cards/impl/minion/monstrous-macaw.js +36 -0
  205. package/dist/cards/impl/minion/monstrous-macaw.js.map +1 -0
  206. package/dist/cards/impl/minion/murkbrine-expeditioner.d.ts +2 -0
  207. package/dist/cards/impl/minion/murkbrine-expeditioner.js +18 -0
  208. package/dist/cards/impl/minion/murkbrine-expeditioner.js.map +1 -0
  209. package/dist/cards/impl/minion/murky.js +3 -2
  210. package/dist/cards/impl/minion/murky.js.map +1 -1
  211. package/dist/cards/impl/minion/mutalisk.js +1 -1
  212. package/dist/cards/impl/minion/mutalisk.js.map +1 -1
  213. package/dist/cards/impl/minion/mutated-lasher.js +1 -2
  214. package/dist/cards/impl/minion/mutated-lasher.js.map +1 -1
  215. package/dist/cards/impl/minion/mythrax.js +1 -2
  216. package/dist/cards/impl/minion/mythrax.js.map +1 -1
  217. package/dist/cards/impl/minion/nerubian-deathswarmer.js +1 -0
  218. package/dist/cards/impl/minion/nerubian-deathswarmer.js.map +1 -1
  219. package/dist/cards/impl/minion/nightmare-par-tea-guest.d.ts +2 -0
  220. package/dist/cards/impl/minion/nightmare-par-tea-guest.js +19 -0
  221. package/dist/cards/impl/minion/nightmare-par-tea-guest.js.map +1 -0
  222. package/dist/cards/impl/minion/noisul-of-the-many-faces.d.ts +2 -0
  223. package/dist/cards/impl/minion/noisul-of-the-many-faces.js +22 -0
  224. package/dist/cards/impl/minion/noisul-of-the-many-faces.js.map +1 -0
  225. package/dist/cards/impl/minion/oozeling-gladiator.js +1 -0
  226. package/dist/cards/impl/minion/oozeling-gladiator.js.map +1 -1
  227. package/dist/cards/impl/minion/parched-wanderer.js +2 -1
  228. package/dist/cards/impl/minion/parched-wanderer.js.map +1 -1
  229. package/dist/cards/impl/minion/peggy-sturdybone.js +1 -2
  230. package/dist/cards/impl/minion/peggy-sturdybone.js.map +1 -1
  231. package/dist/cards/impl/minion/primalfin-lookout.js +1 -0
  232. package/dist/cards/impl/minion/primalfin-lookout.js.map +1 -1
  233. package/dist/cards/impl/minion/prized-promo-drake.js +1 -2
  234. package/dist/cards/impl/minion/prized-promo-drake.js.map +1 -1
  235. package/dist/cards/impl/minion/razorfen-geomancer.js +1 -0
  236. package/dist/cards/impl/minion/razorfen-geomancer.js.map +1 -1
  237. package/dist/cards/impl/minion/razorgore-the-untamed.js +1 -2
  238. package/dist/cards/impl/minion/razorgore-the-untamed.js.map +1 -1
  239. package/dist/cards/impl/minion/rickety-repairbot.d.ts +2 -0
  240. package/dist/cards/impl/minion/rickety-repairbot.js +16 -0
  241. package/dist/cards/impl/minion/rickety-repairbot.js.map +1 -0
  242. package/dist/cards/impl/minion/ripsnarl-captain.js +1 -2
  243. package/dist/cards/impl/minion/ripsnarl-captain.js.map +1 -1
  244. package/dist/cards/impl/minion/roach.js +1 -1
  245. package/dist/cards/impl/minion/roach.js.map +1 -1
  246. package/dist/cards/impl/minion/rodeo-performer.js +1 -0
  247. package/dist/cards/impl/minion/rodeo-performer.js.map +1 -1
  248. package/dist/cards/impl/minion/runed-progenitor.js +1 -1
  249. package/dist/cards/impl/minion/runed-progenitor.js.map +1 -1
  250. package/dist/cards/impl/minion/salty-hog.js +1 -2
  251. package/dist/cards/impl/minion/salty-hog.js.map +1 -1
  252. package/dist/cards/impl/minion/sanctum-rester.js +1 -2
  253. package/dist/cards/impl/minion/sanctum-rester.js.map +1 -1
  254. package/dist/cards/impl/minion/sand-swirler.d.ts +2 -0
  255. package/dist/cards/impl/minion/sand-swirler.js +12 -0
  256. package/dist/cards/impl/minion/sand-swirler.js.map +1 -0
  257. package/dist/cards/impl/minion/sanlayn-scribe.js +2 -2
  258. package/dist/cards/impl/minion/sanlayn-scribe.js.map +1 -1
  259. package/dist/cards/impl/minion/selfless-hero.d.ts +2 -0
  260. package/dist/cards/impl/minion/selfless-hero.js +25 -0
  261. package/dist/cards/impl/minion/selfless-hero.js.map +1 -0
  262. package/dist/cards/impl/minion/shadowdancer.d.ts +2 -0
  263. package/dist/cards/impl/minion/shadowdancer.js +13 -0
  264. package/dist/cards/impl/minion/shadowdancer.js.map +1 -0
  265. package/dist/cards/impl/minion/sharptooth-snapper.d.ts +2 -0
  266. package/dist/cards/impl/minion/sharptooth-snapper.js +8 -0
  267. package/dist/cards/impl/minion/sharptooth-snapper.js.map +1 -0
  268. package/dist/cards/impl/minion/shell-collector.js +1 -0
  269. package/dist/cards/impl/minion/shell-collector.js.map +1 -1
  270. package/dist/cards/impl/minion/silithid-burrower.d.ts +2 -0
  271. package/dist/cards/impl/minion/silithid-burrower.js +18 -0
  272. package/dist/cards/impl/minion/silithid-burrower.js.map +1 -0
  273. package/dist/cards/impl/minion/silky-shimmermoth.d.ts +2 -0
  274. package/dist/cards/impl/minion/silky-shimmermoth.js +20 -0
  275. package/dist/cards/impl/minion/silky-shimmermoth.js.map +1 -0
  276. package/dist/cards/impl/minion/silver-handed-recruit.js +2 -1
  277. package/dist/cards/impl/minion/silver-handed-recruit.js.map +1 -1
  278. package/dist/cards/impl/minion/skulking-bristlemane.d.ts +2 -0
  279. package/dist/cards/impl/minion/skulking-bristlemane.js +17 -0
  280. package/dist/cards/impl/minion/skulking-bristlemane.js.map +1 -0
  281. package/dist/cards/impl/minion/slumber-sorcerer.d.ts +2 -0
  282. package/dist/cards/impl/minion/slumber-sorcerer.js +13 -0
  283. package/dist/cards/impl/minion/slumber-sorcerer.js.map +1 -0
  284. package/dist/cards/impl/minion/smolderwing.js +2 -1
  285. package/dist/cards/impl/minion/smolderwing.js.map +1 -1
  286. package/dist/cards/impl/minion/soul-rewinder.js +5 -1
  287. package/dist/cards/impl/minion/soul-rewinder.js.map +1 -1
  288. package/dist/cards/impl/minion/spacefarer.js +1 -1
  289. package/dist/cards/impl/minion/spacefarer.js.map +1 -1
  290. package/dist/cards/impl/minion/spirited-whimsydrake.d.ts +2 -0
  291. package/dist/cards/impl/minion/spirited-whimsydrake.js +19 -0
  292. package/dist/cards/impl/minion/spirited-whimsydrake.js.map +1 -0
  293. package/dist/cards/impl/minion/springy-spriggan.d.ts +2 -0
  294. package/dist/cards/impl/minion/springy-spriggan.js +21 -0
  295. package/dist/cards/impl/minion/springy-spriggan.js.map +1 -0
  296. package/dist/cards/impl/minion/surfing-slyvar.d.ts +2 -0
  297. package/dist/cards/impl/minion/surfing-slyvar.js +18 -0
  298. package/dist/cards/impl/minion/surfing-slyvar.js.map +1 -0
  299. package/dist/cards/impl/minion/swampstriker.js +1 -1
  300. package/dist/cards/impl/minion/swampstriker.js.map +1 -1
  301. package/dist/cards/impl/minion/thorncaller.d.ts +2 -0
  302. package/dist/cards/impl/minion/thorncaller.js +19 -0
  303. package/dist/cards/impl/minion/thorncaller.js.map +1 -0
  304. package/dist/cards/impl/minion/thousandth-paper-drake.js +1 -2
  305. package/dist/cards/impl/minion/thousandth-paper-drake.js.map +1 -1
  306. package/dist/cards/impl/minion/thundering-abomination.js +1 -2
  307. package/dist/cards/impl/minion/thundering-abomination.js.map +1 -1
  308. package/dist/cards/impl/minion/turquoise-skitterer.js +1 -1
  309. package/dist/cards/impl/minion/turquoise-skitterer.js.map +1 -1
  310. package/dist/cards/impl/minion/twilight-primordium.js +2 -2
  311. package/dist/cards/impl/minion/twilight-primordium.js.map +1 -1
  312. package/dist/cards/impl/minion/ultralisk.js +1 -2
  313. package/dist/cards/impl/minion/ultralisk.js.map +1 -1
  314. package/dist/cards/impl/minion/ultraviolet-ascendant.js +1 -1
  315. package/dist/cards/impl/minion/ultraviolet-ascendant.js.map +1 -1
  316. package/dist/cards/impl/minion/vaelastrasz.js +1 -2
  317. package/dist/cards/impl/minion/vaelastrasz.js.map +1 -1
  318. package/dist/cards/impl/minion/valiant-tiger.d.ts +2 -0
  319. package/dist/cards/impl/minion/valiant-tiger.js +18 -0
  320. package/dist/cards/impl/minion/valiant-tiger.js.map +1 -0
  321. package/dist/cards/impl/minion/void-ray.js +2 -2
  322. package/dist/cards/impl/minion/void-ray.js.map +1 -1
  323. package/dist/cards/impl/minion/vorkai-guardian.d.ts +2 -0
  324. package/dist/cards/impl/minion/vorkai-guardian.js +19 -0
  325. package/dist/cards/impl/minion/vorkai-guardian.js.map +1 -0
  326. package/dist/cards/impl/minion/wandering-wight.js +1 -2
  327. package/dist/cards/impl/minion/wandering-wight.js.map +1 -1
  328. package/dist/cards/impl/minion/whelp-smuggler.js +1 -2
  329. package/dist/cards/impl/minion/whelp-smuggler.js.map +1 -1
  330. package/dist/cards/impl/minion/wisp-in-the-shell.js +2 -1
  331. package/dist/cards/impl/minion/wisp-in-the-shell.js.map +1 -1
  332. package/dist/cards/impl/quest-reward/staff-of-origination.js +1 -2
  333. package/dist/cards/impl/quest-reward/staff-of-origination.js.map +1 -1
  334. package/dist/cards/impl/trinket/all-purpose-kibble.d.ts +2 -0
  335. package/dist/cards/impl/trinket/all-purpose-kibble.js +14 -0
  336. package/dist/cards/impl/trinket/all-purpose-kibble.js.map +1 -0
  337. package/dist/cards/impl/trinket/arm-of-the-empire.js +1 -2
  338. package/dist/cards/impl/trinket/arm-of-the-empire.js.map +1 -1
  339. package/dist/cards/impl/trinket/baleful-incense.d.ts +2 -0
  340. package/dist/cards/impl/trinket/baleful-incense.js +22 -0
  341. package/dist/cards/impl/trinket/baleful-incense.js.map +1 -0
  342. package/dist/cards/impl/trinket/bassgill-portrait.d.ts +2 -0
  343. package/dist/cards/impl/trinket/bassgill-portrait.js +16 -0
  344. package/dist/cards/impl/trinket/bassgill-portrait.js.map +1 -0
  345. package/dist/cards/impl/trinket/battle-horn.d.ts +2 -0
  346. package/dist/cards/impl/trinket/battle-horn.js +20 -0
  347. package/dist/cards/impl/trinket/battle-horn.js.map +1 -0
  348. package/dist/cards/impl/trinket/beetle-band.d.ts +2 -0
  349. package/dist/cards/impl/trinket/beetle-band.js +18 -0
  350. package/dist/cards/impl/trinket/beetle-band.js.map +1 -0
  351. package/dist/cards/impl/trinket/bird-feeder.d.ts +2 -0
  352. package/dist/cards/impl/trinket/bird-feeder.js +13 -0
  353. package/dist/cards/impl/trinket/bird-feeder.js.map +1 -0
  354. package/dist/cards/impl/trinket/bronze-timepiece.js +1 -3
  355. package/dist/cards/impl/trinket/bronze-timepiece.js.map +1 -1
  356. package/dist/cards/impl/trinket/crocheted-sungill.d.ts +2 -0
  357. package/dist/cards/impl/trinket/crocheted-sungill.js +31 -0
  358. package/dist/cards/impl/trinket/crocheted-sungill.js.map +1 -0
  359. package/dist/cards/impl/trinket/divine-signet.d.ts +2 -0
  360. package/dist/cards/impl/trinket/divine-signet.js +14 -0
  361. package/dist/cards/impl/trinket/divine-signet.js.map +1 -0
  362. package/dist/cards/impl/trinket/eclectic-shrine.d.ts +2 -0
  363. package/dist/cards/impl/trinket/eclectic-shrine.js +36 -0
  364. package/dist/cards/impl/trinket/eclectic-shrine.js.map +1 -0
  365. package/dist/cards/impl/trinket/faerie-dragon-scale.d.ts +2 -0
  366. package/dist/cards/impl/trinket/faerie-dragon-scale.js +20 -0
  367. package/dist/cards/impl/trinket/faerie-dragon-scale.js.map +1 -0
  368. package/dist/cards/impl/trinket/herald-sticker.d.ts +2 -0
  369. package/dist/cards/impl/trinket/herald-sticker.js +21 -0
  370. package/dist/cards/impl/trinket/herald-sticker.js.map +1 -0
  371. package/dist/cards/impl/trinket/hogwash-basin.d.ts +2 -0
  372. package/dist/cards/impl/trinket/hogwash-basin.js +14 -0
  373. package/dist/cards/impl/trinket/hogwash-basin.js.map +1 -0
  374. package/dist/cards/impl/trinket/rivendare-portrait.js +1 -2
  375. package/dist/cards/impl/trinket/rivendare-portrait.js.map +1 -1
  376. package/dist/cards/impl/trinket/sthara-sticker.d.ts +2 -0
  377. package/dist/cards/impl/trinket/sthara-sticker.js +32 -0
  378. package/dist/cards/impl/trinket/sthara-sticker.js.map +1 -0
  379. package/dist/cards/impl/trinket/tinyfin-onesie.js +1 -1
  380. package/dist/cards/impl/trinket/tinyfin-onesie.js.map +1 -1
  381. package/dist/cards/impl/trinket/unholy-sanctum.d.ts +2 -0
  382. package/dist/cards/impl/trinket/unholy-sanctum.js +15 -0
  383. package/dist/cards/impl/trinket/unholy-sanctum.js.map +1 -0
  384. package/dist/cards/impl/trinket/vashjir-anemone.d.ts +2 -0
  385. package/dist/cards/impl/trinket/vashjir-anemone.js +13 -0
  386. package/dist/cards/impl/trinket/vashjir-anemone.js.map +1 -0
  387. package/dist/cards/impl/trinket/yulon-sticker.d.ts +2 -0
  388. package/dist/cards/impl/trinket/yulon-sticker.js +20 -0
  389. package/dist/cards/impl/trinket/yulon-sticker.js.map +1 -0
  390. package/dist/keywords/divine-shield.js +19 -6
  391. package/dist/keywords/divine-shield.js.map +1 -1
  392. package/dist/keywords/venomous.js +1 -1
  393. package/dist/keywords/venomous.js.map +1 -1
  394. package/dist/services/utils.d.ts +3 -0
  395. package/dist/services/utils.js.map +1 -1
  396. package/dist/simulate-bgs-battle.js +2 -0
  397. package/dist/simulate-bgs-battle.js.map +1 -1
  398. package/dist/simulation/add-minion-to-board.js +48 -29
  399. package/dist/simulation/add-minion-to-board.js.map +1 -1
  400. package/dist/simulation/after-attack.d.ts +11 -1
  401. package/dist/simulation/after-attack.js +20 -25
  402. package/dist/simulation/after-attack.js.map +1 -1
  403. package/dist/simulation/attack.d.ts +8 -0
  404. package/dist/simulation/attack.js +16 -3
  405. package/dist/simulation/attack.js.map +1 -1
  406. package/dist/simulation/auras.js +14 -12
  407. package/dist/simulation/auras.js.map +1 -1
  408. package/dist/simulation/avenge.js +12 -13
  409. package/dist/simulation/avenge.js.map +1 -1
  410. package/dist/simulation/battlecries.d.ts +1 -0
  411. package/dist/simulation/battlecries.js +28 -36
  412. package/dist/simulation/battlecries.js.map +1 -1
  413. package/dist/simulation/blood-gems.js +8 -3
  414. package/dist/simulation/blood-gems.js.map +1 -1
  415. package/dist/simulation/cards-in-hand.js +1 -2
  416. package/dist/simulation/cards-in-hand.js.map +1 -1
  417. package/dist/simulation/damage-effects.js +4 -8
  418. package/dist/simulation/damage-effects.js.map +1 -1
  419. package/dist/simulation/death-effects.js +1 -2
  420. package/dist/simulation/death-effects.js.map +1 -1
  421. package/dist/simulation/deathrattle-effects.js +25 -55
  422. package/dist/simulation/deathrattle-effects.js.map +1 -1
  423. package/dist/simulation/deathrattle-on-trigger.js +16 -2
  424. package/dist/simulation/deathrattle-on-trigger.js.map +1 -1
  425. package/dist/simulation/deathrattle-spawns.d.ts +1 -0
  426. package/dist/simulation/deathrattle-spawns.js +7 -1
  427. package/dist/simulation/deathrattle-spawns.js.map +1 -1
  428. package/dist/simulation/deathrattle-utils.d.ts +2 -1
  429. package/dist/simulation/deathrattle-utils.js +7 -3
  430. package/dist/simulation/deathrattle-utils.js.map +1 -1
  431. package/dist/simulation/discover.js +1 -1
  432. package/dist/simulation/discover.js.map +1 -1
  433. package/dist/simulation/magnetize.d.ts +9 -1
  434. package/dist/simulation/magnetize.js +17 -3
  435. package/dist/simulation/magnetize.js.map +1 -1
  436. package/dist/simulation/minion-death.js +1 -2
  437. package/dist/simulation/minion-death.js.map +1 -1
  438. package/dist/simulation/minion-kill.js +3 -3
  439. package/dist/simulation/minion-kill.js.map +1 -1
  440. package/dist/simulation/on-attack.js +24 -9
  441. package/dist/simulation/on-attack.js.map +1 -1
  442. package/dist/simulation/on-being-attacked.js +5 -10
  443. package/dist/simulation/on-being-attacked.js.map +1 -1
  444. package/dist/simulation/reborn.js +2 -4
  445. package/dist/simulation/reborn.js.map +1 -1
  446. package/dist/simulation/spawn-fail.js +1 -1
  447. package/dist/simulation/spawn-fail.js.map +1 -1
  448. package/dist/simulation/start-of-combat/soc-action-processor.js +0 -4
  449. package/dist/simulation/start-of-combat/soc-action-processor.js.map +1 -1
  450. package/dist/simulation/start-of-combat/soc-illidan-hero-power.js +2 -4
  451. package/dist/simulation/start-of-combat/soc-illidan-hero-power.js.map +1 -1
  452. package/dist/simulation/start-of-combat/soc-minion.js +10 -2
  453. package/dist/simulation/start-of-combat/soc-minion.js.map +1 -1
  454. package/dist/simulation/start-of-combat/start-of-combat.js +23 -17
  455. package/dist/simulation/start-of-combat/start-of-combat.js.map +1 -1
  456. package/dist/simulation/stats.d.ts +3 -3
  457. package/dist/simulation/stats.js +13 -3
  458. package/dist/simulation/stats.js.map +1 -1
  459. package/dist/simulation/summon-when-space.js +13 -0
  460. package/dist/simulation/summon-when-space.js.map +1 -1
  461. package/dist/simulation/utils/golden.js +1 -1
  462. package/dist/simulation/utils/golden.js.map +1 -1
  463. package/dist/utils.js +11 -16
  464. package/dist/utils.js.map +1 -1
  465. package/package.json +2 -2
  466. package/dist/cards/impl/trinket/artisanal-urn.d.ts +0 -5
  467. package/dist/cards/impl/trinket/artisanal-urn.js +0 -13
  468. package/dist/cards/impl/trinket/artisanal-urn.js.map +0 -1
@@ -10,8 +10,7 @@ exports.ChoralMrrrglr = {
10
10
  ((_b = input.playerEntity.hand) === null || _b === void 0 ? void 0 : _b.map((e) => { var _a; return (_a = e.attack) !== null && _a !== void 0 ? _a : 0; }).reduce((a, b) => a + b, 0)))) !== null && _c !== void 0 ? _c : 0;
11
11
  const healthBuff = (_f = (((_d = input.playerEntity.globalInfo) === null || _d === void 0 ? void 0 : _d.ChoralHealthBuff) ||
12
12
  ((_e = input.playerEntity.hand) === null || _e === void 0 ? void 0 : _e.map((e) => { var _a; return (_a = e.health) !== null && _a !== void 0 ? _a : 0; }).reduce((a, b) => a + b, 0)))) !== null && _f !== void 0 ? _f : 0;
13
- (0, stats_1.modifyStats)(minion, multiplier * attackBuff, multiplier * healthBuff, input.playerBoard, input.playerEntity, input.gameState);
14
- input.gameState.spectator.registerPowerTarget(minion, minion, input.playerBoard, input.playerEntity, input.opponentEntity);
13
+ (0, stats_1.modifyStats)(minion, minion, multiplier * attackBuff, multiplier * healthBuff, input.playerBoard, input.playerEntity, input.gameState);
15
14
  return true;
16
15
  },
17
16
  };
@@ -1 +1 @@
1
- {"version":3,"file":"choral-mrrrglr.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/choral-mrrrglr.ts"],"names":[],"mappings":";;;AAGA,qDAAwD;AAE3C,QAAA,aAAa,GAAG;IAC5B,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;;QACvD,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,iBAAqC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE9E,MAAM,UAAU,GACf,MAAA,CAAC,CAAA,MAAA,KAAK,CAAC,YAAY,CAAC,UAAU,0CAAE,gBAAgB;aAC/C,MAAA,KAAK,CAAC,YAAY,CAAC,IAAI,0CAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,WAAC,OAAA,MAAA,CAAC,CAAC,MAAM,mCAAI,CAAC,CAAA,EAAA,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAA,CAAC,mCAC/E,CAAC,CAAC;QACH,MAAM,UAAU,GACf,MAAA,CAAC,CAAA,MAAA,KAAK,CAAC,YAAY,CAAC,UAAU,0CAAE,gBAAgB;aAC/C,MAAA,KAAK,CAAC,YAAY,CAAC,IAAI,0CAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,WAAC,OAAA,MAAA,CAAC,CAAC,MAAM,mCAAI,CAAC,CAAA,EAAA,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAA,CAAC,mCAC/E,CAAC,CAAC;QACH,IAAA,mBAAW,EACV,MAAM,EACN,UAAU,GAAG,UAAU,EACvB,UAAU,GAAG,UAAU,EACvB,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,SAAS,CACf,CAAC;QACF,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,mBAAmB,CAC5C,MAAM,EACN,MAAM,EACN,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,cAAc,CACpB,CAAC;QACF,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { modifyStats } from '../../../simulation/stats';\r\n\r\nexport const ChoralMrrrglr = {\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst multiplier = minion.cardId === CardIds.ChoralMrrrglr_BG26_354_G ? 2 : 1;\r\n\t\t// When it's summoned by Y'Shaarj hero power, the info isn't set\r\n\t\tconst attackBuff =\r\n\t\t\t(input.playerEntity.globalInfo?.ChoralAttackBuff ||\r\n\t\t\t\tinput.playerEntity.hand?.map((e) => e.attack ?? 0).reduce((a, b) => a + b, 0)) ??\r\n\t\t\t0;\r\n\t\tconst healthBuff =\r\n\t\t\t(input.playerEntity.globalInfo?.ChoralHealthBuff ||\r\n\t\t\t\tinput.playerEntity.hand?.map((e) => e.health ?? 0).reduce((a, b) => a + b, 0)) ??\r\n\t\t\t0;\r\n\t\tmodifyStats(\r\n\t\t\tminion,\r\n\t\t\tmultiplier * attackBuff,\r\n\t\t\tmultiplier * healthBuff,\r\n\t\t\tinput.playerBoard,\r\n\t\t\tinput.playerEntity,\r\n\t\t\tinput.gameState,\r\n\t\t);\r\n\t\tinput.gameState.spectator.registerPowerTarget(\r\n\t\t\tminion,\r\n\t\t\tminion,\r\n\t\t\tinput.playerBoard,\r\n\t\t\tinput.playerEntity,\r\n\t\t\tinput.opponentEntity,\r\n\t\t);\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
1
+ {"version":3,"file":"choral-mrrrglr.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/choral-mrrrglr.ts"],"names":[],"mappings":";;;AAGA,qDAAwD;AAE3C,QAAA,aAAa,GAAG;IAC5B,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;;QACvD,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,iBAAqC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE9E,MAAM,UAAU,GACf,MAAA,CAAC,CAAA,MAAA,KAAK,CAAC,YAAY,CAAC,UAAU,0CAAE,gBAAgB;aAC/C,MAAA,KAAK,CAAC,YAAY,CAAC,IAAI,0CAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,WAAC,OAAA,MAAA,CAAC,CAAC,MAAM,mCAAI,CAAC,CAAA,EAAA,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAA,CAAC,mCAC/E,CAAC,CAAC;QACH,MAAM,UAAU,GACf,MAAA,CAAC,CAAA,MAAA,KAAK,CAAC,YAAY,CAAC,UAAU,0CAAE,gBAAgB;aAC/C,MAAA,KAAK,CAAC,YAAY,CAAC,IAAI,0CAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,WAAC,OAAA,MAAA,CAAC,CAAC,MAAM,mCAAI,CAAC,CAAA,EAAA,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAA,CAAC,mCAC/E,CAAC,CAAC;QACH,IAAA,mBAAW,EACV,MAAM,EACN,MAAM,EACN,UAAU,GAAG,UAAU,EACvB,UAAU,GAAG,UAAU,EACvB,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,SAAS,CACf,CAAC;QACF,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { modifyStats } from '../../../simulation/stats';\r\n\r\nexport const ChoralMrrrglr = {\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst multiplier = minion.cardId === CardIds.ChoralMrrrglr_BG26_354_G ? 2 : 1;\r\n\t\t// When it's summoned by Y'Shaarj hero power, the info isn't set\r\n\t\tconst attackBuff =\r\n\t\t\t(input.playerEntity.globalInfo?.ChoralAttackBuff ||\r\n\t\t\t\tinput.playerEntity.hand?.map((e) => e.attack ?? 0).reduce((a, b) => a + b, 0)) ??\r\n\t\t\t0;\r\n\t\tconst healthBuff =\r\n\t\t\t(input.playerEntity.globalInfo?.ChoralHealthBuff ||\r\n\t\t\t\tinput.playerEntity.hand?.map((e) => e.health ?? 0).reduce((a, b) => a + b, 0)) ??\r\n\t\t\t0;\r\n\t\tmodifyStats(\r\n\t\t\tminion,\r\n\t\t\tminion,\r\n\t\t\tmultiplier * attackBuff,\r\n\t\t\tmultiplier * healthBuff,\r\n\t\t\tinput.playerBoard,\r\n\t\t\tinput.playerEntity,\r\n\t\t\tinput.gameState,\r\n\t\t);\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
@@ -16,9 +16,10 @@ exports.ClunkerJunker = {
16
16
  for (let i = 0; i < numberOfMagnetizes; i++) {
17
17
  const minionToMagnetize = input.gameState.cardsData.getRandomMechToMagnetize((_a = input.hero.tavernTier) !== null && _a !== void 0 ? _a : 1);
18
18
  input.gameState.spectator.registerPowerTarget(minion, junkerTarget, input.board, null, null);
19
- (0, magnetize_1.magnetizeToTarget)(junkerTarget, minionToMagnetize, input.board, input.hero, input.gameState);
19
+ (0, magnetize_1.magnetizeToTarget)(junkerTarget, minion, minionToMagnetize, input.board, input.hero, input.gameState);
20
20
  }
21
21
  }
22
+ return true;
22
23
  },
23
24
  };
24
25
  //# sourceMappingURL=clunker-junker.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"clunker-junker.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/clunker-junker.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAE7D,mDAAqD;AAErD,6DAAkE;AAClE,0CAAiD;AAGpC,QAAA,aAAa,GAAkB;IAC3C,OAAO,EAAE,0BAAkE;IAC3E,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAE,EAAE;;QACzD,MAAM,cAAc,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAC/C,IAAA,uBAAe,EAAC,CAAC,EAAE,KAAK,CAAC,IAAI,EAAE,qBAAI,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAC9F,CAAC;QACF,MAAM,YAAY,GAAG,IAAA,kBAAU,EAAC,cAAc,CAAC,CAAC;QAChD,IAAI,YAAY,EAAE;YACjB,MAAM,kBAAkB,GAAG,MAAM,CAAC,MAAM,eAAmC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACpF,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,kBAAkB,EAAE,CAAC,EAAE,EAAE;gBAC5C,MAAM,iBAAiB,GAAG,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,wBAAwB,CAC3E,MAAA,KAAK,CAAC,IAAI,CAAC,UAAU,mCAAI,CAAC,CAC1B,CAAC;gBACF,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,mBAAmB,CAAC,MAAM,EAAE,YAAY,EAAE,KAAK,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;gBAC7F,IAAA,6BAAiB,EAAC,YAAY,EAAE,iBAAiB,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;aAC7F;SACD;IACF,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, Race } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { pickRandom } from '../../../services/utils';\r\nimport { BattlecryInput } from '../../../simulation/battlecries';\r\nimport { magnetizeToTarget } from '../../../simulation/magnetize';\r\nimport { hasCorrectTribe } from '../../../utils';\r\nimport { BattlecryCard } from '../../card.interface';\r\n\r\nexport const ClunkerJunker: BattlecryCard = {\r\n\tcardIds: [CardIds.ClunkerJunker_BG29_503, CardIds.ClunkerJunker_BG29_503_G],\r\n\tbattlecry: (minion: BoardEntity, input: BattlecryInput) => {\r\n\t\tconst boardWithMechs = input.board.filter((e) =>\r\n\t\t\thasCorrectTribe(e, input.hero, Race.MECH, input.gameState.anomalies, input.gameState.allCards),\r\n\t\t);\r\n\t\tconst junkerTarget = pickRandom(boardWithMechs);\r\n\t\tif (junkerTarget) {\r\n\t\t\tconst numberOfMagnetizes = minion.cardId === CardIds.ClunkerJunker_BG29_503 ? 1 : 2;\r\n\t\t\tfor (let i = 0; i < numberOfMagnetizes; i++) {\r\n\t\t\t\tconst minionToMagnetize = input.gameState.cardsData.getRandomMechToMagnetize(\r\n\t\t\t\t\tinput.hero.tavernTier ?? 1,\r\n\t\t\t\t);\r\n\t\t\t\tinput.gameState.spectator.registerPowerTarget(minion, junkerTarget, input.board, null, null);\r\n\t\t\t\tmagnetizeToTarget(junkerTarget, minionToMagnetize, input.board, input.hero, input.gameState);\r\n\t\t\t}\r\n\t\t}\r\n\t},\r\n};\r\n"]}
1
+ {"version":3,"file":"clunker-junker.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/clunker-junker.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAE7D,mDAAqD;AAErD,6DAAkE;AAClE,0CAAiD;AAGpC,QAAA,aAAa,GAAkB;IAC3C,OAAO,EAAE,0BAAkE;IAC3E,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAE,EAAE;;QACzD,MAAM,cAAc,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAC/C,IAAA,uBAAe,EAAC,CAAC,EAAE,KAAK,CAAC,IAAI,EAAE,qBAAI,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAC9F,CAAC;QACF,MAAM,YAAY,GAAG,IAAA,kBAAU,EAAC,cAAc,CAAC,CAAC;QAChD,IAAI,YAAY,EAAE;YACjB,MAAM,kBAAkB,GAAG,MAAM,CAAC,MAAM,eAAmC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACpF,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,kBAAkB,EAAE,CAAC,EAAE,EAAE;gBAC5C,MAAM,iBAAiB,GAAG,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,wBAAwB,CAC3E,MAAA,KAAK,CAAC,IAAI,CAAC,UAAU,mCAAI,CAAC,CAC1B,CAAC;gBACF,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,mBAAmB,CAAC,MAAM,EAAE,YAAY,EAAE,KAAK,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;gBAC7F,IAAA,6BAAiB,EAAC,YAAY,EAAE,MAAM,EAAE,iBAAiB,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;aACrG;SACD;QACD,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, Race } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { pickRandom } from '../../../services/utils';\r\nimport { BattlecryInput } from '../../../simulation/battlecries';\r\nimport { magnetizeToTarget } from '../../../simulation/magnetize';\r\nimport { hasCorrectTribe } from '../../../utils';\r\nimport { BattlecryCard } from '../../card.interface';\r\n\r\nexport const ClunkerJunker: BattlecryCard = {\r\n\tcardIds: [CardIds.ClunkerJunker_BG29_503, CardIds.ClunkerJunker_BG29_503_G],\r\n\tbattlecry: (minion: BoardEntity, input: BattlecryInput) => {\r\n\t\tconst boardWithMechs = input.board.filter((e) =>\r\n\t\t\thasCorrectTribe(e, input.hero, Race.MECH, input.gameState.anomalies, input.gameState.allCards),\r\n\t\t);\r\n\t\tconst junkerTarget = pickRandom(boardWithMechs);\r\n\t\tif (junkerTarget) {\r\n\t\t\tconst numberOfMagnetizes = minion.cardId === CardIds.ClunkerJunker_BG29_503 ? 1 : 2;\r\n\t\t\tfor (let i = 0; i < numberOfMagnetizes; i++) {\r\n\t\t\t\tconst minionToMagnetize = input.gameState.cardsData.getRandomMechToMagnetize(\r\n\t\t\t\t\tinput.hero.tavernTier ?? 1,\r\n\t\t\t\t);\r\n\t\t\t\tinput.gameState.spectator.registerPowerTarget(minion, junkerTarget, input.board, null, null);\r\n\t\t\t\tmagnetizeToTarget(junkerTarget, minion, minionToMagnetize, input.board, input.hero, input.gameState);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { DeathrattleEffectCard } from '../../card.interface';
2
+ export declare const CoilskarSapper: DeathrattleEffectCard;
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CoilskarSapper = void 0;
4
+ const cards_in_hand_1 = require("../../../simulation/cards-in-hand");
5
+ exports.CoilskarSapper = {
6
+ cardIds: ["BG32_836", "BG32_836_G"],
7
+ deathrattleEffect: (minion, input) => {
8
+ const mult = minion.cardId === "BG32_836_G" ? 2 : 1;
9
+ const cardsToAdd = Array(2 * mult).fill(null);
10
+ (0, cards_in_hand_1.addCardsInHand)(input.boardWithDeadEntityHero, input.boardWithDeadEntity, cardsToAdd, input.gameState);
11
+ },
12
+ };
13
+ //# sourceMappingURL=coilskar-sapper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"coilskar-sapper.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/coilskar-sapper.ts"],"names":[],"mappings":";;;AAEA,qEAAmE;AAItD,QAAA,cAAc,GAA0B;IACpD,OAAO,EAAE,0BAAoE;IAC7E,iBAAiB,EAAE,CAAC,MAAmB,EAAE,KAAgC,EAAE,EAAE;QAC5E,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAAsC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACzE,MAAM,UAAU,GAAG,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9C,IAAA,8BAAc,EAAC,KAAK,CAAC,uBAAuB,EAAE,KAAK,CAAC,mBAAmB,EAAE,UAAU,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;IACvG,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { addCardsInHand } from '../../../simulation/cards-in-hand';\r\nimport { DeathrattleTriggeredInput } from '../../../simulation/deathrattle-on-trigger';\r\nimport { DeathrattleEffectCard } from '../../card.interface';\r\n\r\nexport const CoilskarSapper: DeathrattleEffectCard = {\r\n\tcardIds: [CardIds.CoilskarSapper_BG32_836, CardIds.CoilskarSapper_BG32_836_G],\r\n\tdeathrattleEffect: (minion: BoardEntity, input: DeathrattleTriggeredInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.CoilskarSapper_BG32_836_G ? 2 : 1;\r\n\t\tconst cardsToAdd = Array(2 * mult).fill(null);\r\n\t\taddCardsInHand(input.boardWithDeadEntityHero, input.boardWithDeadEntity, cardsToAdd, input.gameState);\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { DeathrattleSpawnCard } from '../../card.interface';
2
+ export declare const CorruptedBristler: DeathrattleSpawnCard;
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CorruptedBristler = void 0;
4
+ const deathrattle_spawns_1 = require("../../../simulation/deathrattle-spawns");
5
+ exports.CorruptedBristler = {
6
+ cardIds: ["BG32_431", "BG32_431_G"],
7
+ deathrattleSpawn: (minion, input) => {
8
+ var _a, _b;
9
+ let bloodGemEnchantments = (_a = minion.enchantments) === null || _a === void 0 ? void 0 : _a.filter((e) => e.cardId === "BG20_GEMe2");
10
+ if ((bloodGemEnchantments === null || bloodGemEnchantments === void 0 ? void 0 : bloodGemEnchantments.length) === 0) {
11
+ bloodGemEnchantments = (_b = minion.enchantments) === null || _b === void 0 ? void 0 : _b.filter((e) => e.cardId === "BG20_GEMe");
12
+ }
13
+ const allSpawns = [];
14
+ if ((bloodGemEnchantments === null || bloodGemEnchantments === void 0 ? void 0 : bloodGemEnchantments.length) > 0) {
15
+ const bloodGemAttack = bloodGemEnchantments.map((e) => { var _a; return (_a = e.tagScriptDataNum1) !== null && _a !== void 0 ? _a : 0; }).reduce((a, b) => a + b, 0);
16
+ const bloodGemHealth = bloodGemEnchantments.map((e) => { var _a; return (_a = e.tagScriptDataNum2) !== null && _a !== void 0 ? _a : 0; }).reduce((a, b) => a + b, 0);
17
+ if (bloodGemAttack > 0 || bloodGemHealth > 0) {
18
+ const mult = minion.cardId === "BG32_431_G" ? 2 : 1;
19
+ for (let i = 0; i < mult; i++) {
20
+ const spawns = (0, deathrattle_spawns_1.simplifiedSpawnEntities)("BG30_MagicItem_442t", 1, input);
21
+ spawns.forEach((b) => {
22
+ b.attack = bloodGemAttack;
23
+ b.health = bloodGemHealth;
24
+ });
25
+ allSpawns.push(...spawns);
26
+ }
27
+ }
28
+ }
29
+ return allSpawns;
30
+ },
31
+ };
32
+ //# sourceMappingURL=corrupted-bristler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"corrupted-bristler.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/corrupted-bristler.ts"],"names":[],"mappings":";;;AAGA,+EAAiF;AAGpE,QAAA,iBAAiB,GAAyB;IACtD,OAAO,EAAE,0BAA0E;IACnF,gBAAgB,EAAE,CAAC,MAAmB,EAAE,KAAgC,EAA0B,EAAE;;QACnG,IAAI,oBAAoB,GAAG,MAAA,MAAM,CAAC,YAAY,0CAAE,MAAM,CACrD,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,iBAA0C,CACzD,CAAC;QACF,IAAI,CAAA,oBAAoB,aAApB,oBAAoB,uBAApB,oBAAoB,CAAE,MAAM,MAAK,CAAC,EAAE;YACvC,oBAAoB,GAAG,MAAA,MAAM,CAAC,YAAY,0CAAE,MAAM,CACjD,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,gBAAyC,CACxD,CAAC;SACF;QACD,MAAM,SAAS,GAAG,EAAE,CAAC;QACrB,IAAI,CAAA,oBAAoB,aAApB,oBAAoB,uBAApB,oBAAoB,CAAE,MAAM,IAAG,CAAC,EAAE;YACrC,MAAM,cAAc,GAAG,oBAAoB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,WAAC,OAAA,MAAA,CAAC,CAAC,iBAAiB,mCAAI,CAAC,CAAA,EAAA,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;YAC5G,MAAM,cAAc,GAAG,oBAAoB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,WAAC,OAAA,MAAA,CAAC,CAAC,iBAAiB,mCAAI,CAAC,CAAA,EAAA,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;YAC5G,IAAI,cAAc,GAAG,CAAC,IAAI,cAAc,GAAG,CAAC,EAAE;gBAC7C,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAAyC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC5E,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;oBAC9B,MAAM,MAAM,GAAG,IAAA,4CAAuB,yBAErC,CAAC,EACD,KAAK,CACL,CAAC;oBACF,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;wBACpB,CAAC,CAAC,MAAM,GAAG,cAAc,CAAC;wBAC1B,CAAC,CAAC,MAAM,GAAG,cAAc,CAAC;oBAC3B,CAAC,CAAC,CAAC;oBACH,SAAS,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC;iBAC1B;aACD;SACD;QACD,OAAO,SAAS,CAAC;IAClB,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { DeathrattleTriggeredInput } from '../../../simulation/deathrattle-on-trigger';\r\nimport { simplifiedSpawnEntities } from '../../../simulation/deathrattle-spawns';\r\nimport { DeathrattleSpawnCard } from '../../card.interface';\r\n\r\nexport const CorruptedBristler: DeathrattleSpawnCard = {\r\n\tcardIds: [CardIds.CorruptedBristler_BG32_431, CardIds.CorruptedBristler_BG32_431_G],\r\n\tdeathrattleSpawn: (minion: BoardEntity, input: DeathrattleTriggeredInput): readonly BoardEntity[] => {\r\n\t\tlet bloodGemEnchantments = minion.enchantments?.filter(\r\n\t\t\t(e) => e.cardId === CardIds.BloodGem_BloodGemsEnchantment,\r\n\t\t);\r\n\t\tif (bloodGemEnchantments?.length === 0) {\r\n\t\t\tbloodGemEnchantments = minion.enchantments?.filter(\r\n\t\t\t\t(e) => e.cardId === CardIds.BloodGem_BloodGemEnchantment,\r\n\t\t\t);\r\n\t\t}\r\n\t\tconst allSpawns = [];\r\n\t\tif (bloodGemEnchantments?.length > 0) {\r\n\t\t\tconst bloodGemAttack = bloodGemEnchantments.map((e) => e.tagScriptDataNum1 ?? 0).reduce((a, b) => a + b, 0);\r\n\t\t\tconst bloodGemHealth = bloodGemEnchantments.map((e) => e.tagScriptDataNum2 ?? 0).reduce((a, b) => a + b, 0);\r\n\t\t\tif (bloodGemAttack > 0 || bloodGemHealth > 0) {\r\n\t\t\t\tconst mult = minion.cardId === CardIds.CorruptedBristler_BG32_431_G ? 2 : 1;\r\n\t\t\t\tfor (let i = 0; i < mult; i++) {\r\n\t\t\t\t\tconst spawns = simplifiedSpawnEntities(\r\n\t\t\t\t\t\tCardIds.BloodGolemSticker_BloodGolemToken_BG30_MagicItem_442t,\r\n\t\t\t\t\t\t1,\r\n\t\t\t\t\t\tinput,\r\n\t\t\t\t\t);\r\n\t\t\t\t\tspawns.forEach((b) => {\r\n\t\t\t\t\t\tb.attack = bloodGemAttack;\r\n\t\t\t\t\t\tb.health = bloodGemHealth;\r\n\t\t\t\t\t});\r\n\t\t\t\t\tallSpawns.push(...spawns);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn allSpawns;\r\n\t},\r\n};\r\n"]}
@@ -6,8 +6,7 @@ exports.CorruptedMyrmidon = {
6
6
  cardIds: ["BG23_012", "BG23_012_G"],
7
7
  startOfCombat: (minion, input) => {
8
8
  const multiplier = minion.cardId === "BG23_012_G" ? 2 : 1;
9
- (0, stats_1.modifyStats)(minion, multiplier * minion.maxAttack, multiplier * minion.maxHealth, input.playerBoard, input.playerEntity, input.gameState);
10
- input.gameState.spectator.registerPowerTarget(minion, minion, input.playerBoard, input.playerEntity, input.opponentEntity);
9
+ (0, stats_1.modifyStats)(minion, minion, multiplier * minion.maxAttack, multiplier * minion.maxHealth, input.playerBoard, input.playerEntity, input.gameState);
11
10
  return true;
12
11
  },
13
12
  };
@@ -1 +1 @@
1
- {"version":3,"file":"corrupted-myrmidon.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/corrupted-myrmidon.ts"],"names":[],"mappings":";;;AAGA,qDAAwD;AAG3C,QAAA,iBAAiB,GAAsB;IACnD,OAAO,EAAE,0BAA0E;IACnF,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QAEvD,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,iBAAyC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAKlF,IAAA,mBAAW,EACV,MAAM,EACN,UAAU,GAAG,MAAM,CAAC,SAAS,EAC7B,UAAU,GAAG,MAAM,CAAC,SAAS,EAC7B,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,SAAS,CACf,CAAC;QACF,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,mBAAmB,CAC5C,MAAM,EACN,MAAM,EACN,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,cAAc,CACpB,CAAC;QACF,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { StartOfCombatCard } from '../../card.interface';\r\n\r\nexport const CorruptedMyrmidon: StartOfCombatCard = {\r\n\tcardIds: [CardIds.CorruptedMyrmidon_BG23_012, CardIds.CorruptedMyrmidon_BG23_012_G],\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\t// We add these stats\r\n\t\tconst multiplier = minion.cardId === CardIds.CorruptedMyrmidon_BG23_012_G ? 2 : 1;\r\n\t\t// Tt remembers the \"max stats\" it had, and adds these, instead of the current ones.\r\n\t\t// // Or alternatively, that the stat gain is computed before other effects happen, then is applied\r\n\t\t// https://replays.firestoneapp.com/?reviewId=10a78c2e-d16d-4593-86c8-15eb4cc81a3e&turn=11&action=1\r\n\t\t// I'll go with the max stats for now, since it's easier to implement\r\n\t\tmodifyStats(\r\n\t\t\tminion,\r\n\t\t\tmultiplier * minion.maxAttack,\r\n\t\t\tmultiplier * minion.maxHealth,\r\n\t\t\tinput.playerBoard,\r\n\t\t\tinput.playerEntity,\r\n\t\t\tinput.gameState,\r\n\t\t);\r\n\t\tinput.gameState.spectator.registerPowerTarget(\r\n\t\t\tminion,\r\n\t\t\tminion,\r\n\t\t\tinput.playerBoard,\r\n\t\t\tinput.playerEntity,\r\n\t\t\tinput.opponentEntity,\r\n\t\t);\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
1
+ {"version":3,"file":"corrupted-myrmidon.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/corrupted-myrmidon.ts"],"names":[],"mappings":";;;AAGA,qDAAwD;AAG3C,QAAA,iBAAiB,GAAsB;IACnD,OAAO,EAAE,0BAA0E;IACnF,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QAEvD,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,iBAAyC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAKlF,IAAA,mBAAW,EACV,MAAM,EACN,MAAM,EACN,UAAU,GAAG,MAAM,CAAC,SAAS,EAC7B,UAAU,GAAG,MAAM,CAAC,SAAS,EAC7B,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,SAAS,CACf,CAAC;QACF,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { StartOfCombatCard } from '../../card.interface';\r\n\r\nexport const CorruptedMyrmidon: StartOfCombatCard = {\r\n\tcardIds: [CardIds.CorruptedMyrmidon_BG23_012, CardIds.CorruptedMyrmidon_BG23_012_G],\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\t// We add these stats\r\n\t\tconst multiplier = minion.cardId === CardIds.CorruptedMyrmidon_BG23_012_G ? 2 : 1;\r\n\t\t// Tt remembers the \"max stats\" it had, and adds these, instead of the current ones.\r\n\t\t// // Or alternatively, that the stat gain is computed before other effects happen, then is applied\r\n\t\t// https://replays.firestoneapp.com/?reviewId=10a78c2e-d16d-4593-86c8-15eb4cc81a3e&turn=11&action=1\r\n\t\t// I'll go with the max stats for now, since it's easier to implement\r\n\t\tmodifyStats(\r\n\t\t\tminion,\r\n\t\t\tminion,\r\n\t\t\tmultiplier * minion.maxAttack,\r\n\t\t\tmultiplier * minion.maxHealth,\r\n\t\t\tinput.playerBoard,\r\n\t\t\tinput.playerEntity,\r\n\t\t\tinput.gameState,\r\n\t\t);\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
@@ -9,8 +9,7 @@ exports.Crabby = {
9
9
  const multiplier = minion.cardId === "BG22_HERO_000_Buddy_G" ? 2 : 1;
10
10
  neighbours.forEach((entity) => {
11
11
  var _a, _b;
12
- (0, stats_1.modifyStats)(entity, multiplier * ((_a = input.playerEntity.deadEyeDamageDone) !== null && _a !== void 0 ? _a : 0), multiplier * ((_b = input.playerEntity.deadEyeDamageDone) !== null && _b !== void 0 ? _b : 0), input.playerBoard, input.playerEntity, input.gameState);
13
- input.gameState.spectator.registerPowerTarget(minion, entity, input.playerBoard, input.playerEntity, input.opponentEntity);
12
+ (0, stats_1.modifyStats)(entity, minion, multiplier * ((_a = input.playerEntity.deadEyeDamageDone) !== null && _a !== void 0 ? _a : 0), multiplier * ((_b = input.playerEntity.deadEyeDamageDone) !== null && _b !== void 0 ? _b : 0), input.playerBoard, input.playerEntity, input.gameState);
14
13
  });
15
14
  return true;
16
15
  },
@@ -1 +1 @@
1
- {"version":3,"file":"crabby.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/crabby.ts"],"names":[],"mappings":";;;AAEA,uDAA2D;AAE3D,qDAAwD;AAE3C,QAAA,MAAM,GAAG;IACrB,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QACvD,MAAM,UAAU,GAAG,IAAA,sBAAa,EAAC,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;QAC5D,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,4BAAyC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAClF,UAAU,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;;YAC7B,IAAA,mBAAW,EACV,MAAM,EACN,UAAU,GAAG,CAAC,MAAA,KAAK,CAAC,YAAY,CAAC,iBAAiB,mCAAI,CAAC,CAAC,EACxD,UAAU,GAAG,CAAC,MAAA,KAAK,CAAC,YAAY,CAAC,iBAAiB,mCAAI,CAAC,CAAC,EACxD,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,SAAS,CACf,CAAC;YACF,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,mBAAmB,CAC5C,MAAM,EACN,MAAM,EACN,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,cAAc,CACpB,CAAC;QACH,CAAC,CAAC,CAAC;QACH,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { getNeighbours } from '../../../simulation/attack';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { modifyStats } from '../../../simulation/stats';\r\n\r\nexport const Crabby = {\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst neighbours = getNeighbours(input.playerBoard, minion);\r\n\t\tconst multiplier = minion.cardId === CardIds.Crabby_BG22_HERO_000_Buddy_G ? 2 : 1;\r\n\t\tneighbours.forEach((entity) => {\r\n\t\t\tmodifyStats(\r\n\t\t\t\tentity,\r\n\t\t\t\tmultiplier * (input.playerEntity.deadEyeDamageDone ?? 0),\r\n\t\t\t\tmultiplier * (input.playerEntity.deadEyeDamageDone ?? 0),\r\n\t\t\t\tinput.playerBoard,\r\n\t\t\t\tinput.playerEntity,\r\n\t\t\t\tinput.gameState,\r\n\t\t\t);\r\n\t\t\tinput.gameState.spectator.registerPowerTarget(\r\n\t\t\t\tminion,\r\n\t\t\t\tentity,\r\n\t\t\t\tinput.playerBoard,\r\n\t\t\t\tinput.playerEntity,\r\n\t\t\t\tinput.opponentEntity,\r\n\t\t\t);\r\n\t\t});\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
1
+ {"version":3,"file":"crabby.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/crabby.ts"],"names":[],"mappings":";;;AAEA,uDAA2D;AAE3D,qDAAwD;AAE3C,QAAA,MAAM,GAAG;IACrB,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QACvD,MAAM,UAAU,GAAG,IAAA,sBAAa,EAAC,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;QAC5D,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,4BAAyC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAClF,UAAU,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;;YAC7B,IAAA,mBAAW,EACV,MAAM,EACN,MAAM,EACN,UAAU,GAAG,CAAC,MAAA,KAAK,CAAC,YAAY,CAAC,iBAAiB,mCAAI,CAAC,CAAC,EACxD,UAAU,GAAG,CAAC,MAAA,KAAK,CAAC,YAAY,CAAC,iBAAiB,mCAAI,CAAC,CAAC,EACxD,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,SAAS,CACf,CAAC;QACH,CAAC,CAAC,CAAC;QACH,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { getNeighbours } from '../../../simulation/attack';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { modifyStats } from '../../../simulation/stats';\r\n\r\nexport const Crabby = {\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst neighbours = getNeighbours(input.playerBoard, minion);\r\n\t\tconst multiplier = minion.cardId === CardIds.Crabby_BG22_HERO_000_Buddy_G ? 2 : 1;\r\n\t\tneighbours.forEach((entity) => {\r\n\t\t\tmodifyStats(\r\n\t\t\t\tentity,\r\n\t\t\t\tminion,\r\n\t\t\t\tmultiplier * (input.playerEntity.deadEyeDamageDone ?? 0),\r\n\t\t\t\tmultiplier * (input.playerEntity.deadEyeDamageDone ?? 0),\r\n\t\t\t\tinput.playerBoard,\r\n\t\t\t\tinput.playerEntity,\r\n\t\t\t\tinput.gameState,\r\n\t\t\t);\r\n\t\t});\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { OnCardAddedToHandCard } from '../../card.interface';
2
+ export declare const DastardlyDrust: OnCardAddedToHandCard;
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DastardlyDrust = void 0;
4
+ const reference_data_1 = require("@firestone-hs/reference-data");
5
+ const stats_1 = require("../../../simulation/stats");
6
+ const utils_1 = require("../../../utils");
7
+ exports.DastardlyDrust = {
8
+ cardIds: ["BG32_234", "BG32_234_G"],
9
+ onCardAddedToHand: (minion, input) => {
10
+ if ((0, utils_1.hasCorrectTribe)(input.addedCard, input.hero, reference_data_1.Race.PIRATE, input.gameState.anomalies, input.gameState.allCards)) {
11
+ const mult = minion.cardId === "BG32_234_G" ? 2 : 1;
12
+ const targets = input.board.filter((e) => e.entityId !== minion.entityId);
13
+ for (const target of targets) {
14
+ const buff = (0, utils_1.isGolden)(target.cardId, input.gameState.allCards) ? 2 * mult : 1 * mult;
15
+ (0, stats_1.modifyStats)(target, minion, 1 * buff, 1 * buff, input.board, input.hero, input.gameState);
16
+ }
17
+ }
18
+ },
19
+ };
20
+ //# sourceMappingURL=dastardly-drust.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dastardly-drust.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/dastardly-drust.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAG7D,qDAAwD;AACxD,0CAA2D;AAG9C,QAAA,cAAc,GAA0B;IACpD,OAAO,EAAE,0BAAoE;IAC7E,iBAAiB,EAAE,CAAC,MAAmB,EAAE,KAA6B,EAAE,EAAE;QACzE,IACC,IAAA,uBAAe,EACd,KAAK,CAAC,SAAS,EACf,KAAK,CAAC,IAAI,EACV,qBAAI,CAAC,MAAM,EACX,KAAK,CAAC,SAAS,CAAC,SAAS,EACzB,KAAK,CAAC,SAAS,CAAC,QAAQ,CACxB,EACA;YACD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAAsC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACzE,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC;YAC1E,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;gBAC7B,MAAM,IAAI,GAAG,IAAA,gBAAQ,EAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;gBACrF,IAAA,mBAAW,EAAC,MAAM,EAAE,MAAM,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,GAAG,IAAI,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;aAC1F;SACD;IACF,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, Race } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { OnCardAddedToHandInput } from '../../../simulation/cards-in-hand';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { hasCorrectTribe, isGolden } from '../../../utils';\r\nimport { OnCardAddedToHandCard } from '../../card.interface';\r\n\r\nexport const DastardlyDrust: OnCardAddedToHandCard = {\r\n\tcardIds: [CardIds.DastardlyDrust_BG32_234, CardIds.DastardlyDrust_BG32_234_G],\r\n\tonCardAddedToHand: (minion: BoardEntity, input: OnCardAddedToHandInput) => {\r\n\t\tif (\r\n\t\t\thasCorrectTribe(\r\n\t\t\t\tinput.addedCard,\r\n\t\t\t\tinput.hero,\r\n\t\t\t\tRace.PIRATE,\r\n\t\t\t\tinput.gameState.anomalies,\r\n\t\t\t\tinput.gameState.allCards,\r\n\t\t\t)\r\n\t\t) {\r\n\t\t\tconst mult = minion.cardId === CardIds.DastardlyDrust_BG32_234_G ? 2 : 1;\r\n\t\t\tconst targets = input.board.filter((e) => e.entityId !== minion.entityId);\r\n\t\t\tfor (const target of targets) {\r\n\t\t\t\tconst buff = isGolden(target.cardId, input.gameState.allCards) ? 2 * mult : 1 * mult;\r\n\t\t\t\tmodifyStats(target, minion, 1 * buff, 1 * buff, input.board, input.hero, input.gameState);\r\n\t\t\t}\r\n\t\t}\r\n\t},\r\n};\r\n"]}
@@ -8,8 +8,7 @@ exports.Deadstomper = {
8
8
  if (minion.entityId !== input.spawned.entityId) {
9
9
  const mult = minion.cardId === "BG28_634_G" ? 2 : 1;
10
10
  input.board.forEach((e) => {
11
- (0, stats_1.modifyStats)(e, 4 * mult, 0, input.board, input.hero, input.gameState);
12
- input.gameState.spectator.registerPowerTarget(minion, e, input.board, null, null);
11
+ (0, stats_1.modifyStats)(e, minion, 4 * mult, 0, input.board, input.hero, input.gameState);
13
12
  });
14
13
  }
15
14
  },
@@ -1 +1 @@
1
- {"version":3,"file":"deadstomper.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/deadstomper.ts"],"names":[],"mappings":";;;AAGA,qDAAwD;AAG3C,QAAA,WAAW,GAA0B;IACjD,OAAO,EAAE,0BAA8D;IACvE,iBAAiB,EAAE,CAAC,MAAmB,EAAE,KAA4B,EAAE,EAAE;QACxE,IAAI,MAAM,CAAC,QAAQ,KAAK,KAAK,CAAC,OAAO,CAAC,QAAQ,EAAE;YAC/C,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAAmC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACtE,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;gBACzB,IAAA,mBAAW,EAAC,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;gBACtE,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,mBAAmB,CAAC,MAAM,EAAE,CAAC,EAAE,KAAK,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;YACnF,CAAC,CAAC,CAAC;SACH;IACF,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { OnOtherSpawnAuraInput } from '../../../simulation/add-minion-to-board';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { AfterOtherSpawnedCard } from '../../card.interface';\r\n\r\nexport const Deadstomper: AfterOtherSpawnedCard = {\r\n\tcardIds: [CardIds.Deadstomper_BG28_634, CardIds.Deadstomper_BG28_634_G],\r\n\tafterOtherSpawned: (minion: BoardEntity, input: OnOtherSpawnAuraInput) => {\r\n\t\tif (minion.entityId !== input.spawned.entityId) {\r\n\t\t\tconst mult = minion.cardId === CardIds.Deadstomper_BG28_634_G ? 2 : 1;\r\n\t\t\tinput.board.forEach((e) => {\r\n\t\t\t\tmodifyStats(e, 4 * mult, 0, input.board, input.hero, input.gameState);\r\n\t\t\t\tinput.gameState.spectator.registerPowerTarget(minion, e, input.board, null, null);\r\n\t\t\t});\r\n\t\t}\r\n\t},\r\n};\r\n"]}
1
+ {"version":3,"file":"deadstomper.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/deadstomper.ts"],"names":[],"mappings":";;;AAGA,qDAAwD;AAG3C,QAAA,WAAW,GAA0B;IACjD,OAAO,EAAE,0BAA8D;IACvE,iBAAiB,EAAE,CAAC,MAAmB,EAAE,KAA4B,EAAE,EAAE;QACxE,IAAI,MAAM,CAAC,QAAQ,KAAK,KAAK,CAAC,OAAO,CAAC,QAAQ,EAAE;YAC/C,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAAmC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACtE,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;gBACzB,IAAA,mBAAW,EAAC,CAAC,EAAE,MAAM,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;YAC/E,CAAC,CAAC,CAAC;SACH;IACF,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { OnOtherSpawnAuraInput } from '../../../simulation/add-minion-to-board';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { AfterOtherSpawnedCard } from '../../card.interface';\r\n\r\nexport const Deadstomper: AfterOtherSpawnedCard = {\r\n\tcardIds: [CardIds.Deadstomper_BG28_634, CardIds.Deadstomper_BG28_634_G],\r\n\tafterOtherSpawned: (minion: BoardEntity, input: OnOtherSpawnAuraInput) => {\r\n\t\tif (minion.entityId !== input.spawned.entityId) {\r\n\t\t\tconst mult = minion.cardId === CardIds.Deadstomper_BG28_634_G ? 2 : 1;\r\n\t\t\tinput.board.forEach((e) => {\r\n\t\t\t\tmodifyStats(e, minion, 4 * mult, 0, input.board, input.hero, input.gameState);\r\n\t\t\t});\r\n\t\t}\r\n\t},\r\n};\r\n"]}
@@ -13,8 +13,7 @@ exports.DeflectoBot = {
13
13
  if (!minion.divineShield) {
14
14
  (0, divine_shield_1.updateDivineShield)(minion, input.board, input.hero, input.otherHero, true, input.gameState);
15
15
  }
16
- (0, stats_1.modifyStats)(minion, statsBonus, 0, input.board, input.hero, input.gameState);
17
- input.gameState.spectator.registerPowerTarget(minion, minion, input.board, input.hero, input.otherHero);
16
+ (0, stats_1.modifyStats)(minion, minion, statsBonus, 0, input.board, input.hero, input.gameState);
18
17
  }
19
18
  },
20
19
  };
@@ -1 +1 @@
1
- {"version":3,"file":"deflecto-bot.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/deflecto-bot.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAE7D,mEAAqE;AAErE,qDAAwD;AACxD,0CAAiD;AAGpC,QAAA,WAAW,GAAuB;IAC9C,OAAO,EAAE,8BAAkE;IAC3E,cAAc,EAAE,CAAC,MAAmB,EAAE,KAAwB,EAAE,EAAE;QACjE,IACC,IAAA,uBAAe,EAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,IAAI,EAAE,qBAAI,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,EACzG;YACD,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,sBAAwC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACjF,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE;gBACzB,IAAA,kCAAkB,EAAC,MAAM,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,EAAE,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;aAC5F;YACD,IAAA,mBAAW,EAAC,MAAM,EAAE,UAAU,EAAE,CAAC,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;YAC7E,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;SACxG;IACF,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, Race } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { updateDivineShield } from '../../../keywords/divine-shield';\r\nimport { OnOtherSpawnInput } from '../../../simulation/add-minion-to-board';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { hasCorrectTribe } from '../../../utils';\r\nimport { OnOtherSpawnedCard } from '../../card.interface';\r\n\r\nexport const DeflectoBot: OnOtherSpawnedCard = {\r\n\tcardIds: [CardIds.DeflectOBot_BGS_071, CardIds.DeflectOBot_TB_BaconUps_123],\r\n\tonOtherSpawned: (minion: BoardEntity, input: OnOtherSpawnInput) => {\r\n\t\tif (\r\n\t\t\thasCorrectTribe(input.spawned, input.hero, Race.MECH, input.gameState.anomalies, input.gameState.allCards)\r\n\t\t) {\r\n\t\t\tconst statsBonus = minion.cardId === CardIds.DeflectOBot_TB_BaconUps_123 ? 4 : 2;\r\n\t\t\tif (!minion.divineShield) {\r\n\t\t\t\tupdateDivineShield(minion, input.board, input.hero, input.otherHero, true, input.gameState);\r\n\t\t\t}\r\n\t\t\tmodifyStats(minion, statsBonus, 0, input.board, input.hero, input.gameState);\r\n\t\t\tinput.gameState.spectator.registerPowerTarget(minion, minion, input.board, input.hero, input.otherHero);\r\n\t\t}\r\n\t},\r\n};\r\n"]}
1
+ {"version":3,"file":"deflecto-bot.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/deflecto-bot.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAE7D,mEAAqE;AAErE,qDAAwD;AACxD,0CAAiD;AAGpC,QAAA,WAAW,GAAuB;IAC9C,OAAO,EAAE,8BAAkE;IAC3E,cAAc,EAAE,CAAC,MAAmB,EAAE,KAAwB,EAAE,EAAE;QACjE,IACC,IAAA,uBAAe,EAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,IAAI,EAAE,qBAAI,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,EACzG;YACD,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,sBAAwC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACjF,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE;gBACzB,IAAA,kCAAkB,EAAC,MAAM,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,EAAE,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;aAC5F;YACD,IAAA,mBAAW,EAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;SACrF;IACF,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, Race } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { updateDivineShield } from '../../../keywords/divine-shield';\r\nimport { OnOtherSpawnInput } from '../../../simulation/add-minion-to-board';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { hasCorrectTribe } from '../../../utils';\r\nimport { OnOtherSpawnedCard } from '../../card.interface';\r\n\r\nexport const DeflectoBot: OnOtherSpawnedCard = {\r\n\tcardIds: [CardIds.DeflectOBot_BGS_071, CardIds.DeflectOBot_TB_BaconUps_123],\r\n\tonOtherSpawned: (minion: BoardEntity, input: OnOtherSpawnInput) => {\r\n\t\tif (\r\n\t\t\thasCorrectTribe(input.spawned, input.hero, Race.MECH, input.gameState.anomalies, input.gameState.allCards)\r\n\t\t) {\r\n\t\t\tconst statsBonus = minion.cardId === CardIds.DeflectOBot_TB_BaconUps_123 ? 4 : 2;\r\n\t\t\tif (!minion.divineShield) {\r\n\t\t\t\tupdateDivineShield(minion, input.board, input.hero, input.otherHero, true, input.gameState);\r\n\t\t\t}\r\n\t\t\tmodifyStats(minion, minion, statsBonus, 0, input.board, input.hero, input.gameState);\r\n\t\t}\r\n\t},\r\n};\r\n"]}
@@ -15,8 +15,7 @@ exports.DiremuckForager = {
15
15
  if (potentialTargets.length > 0) {
16
16
  const target = (0, utils_1.pickRandom)(potentialTargets);
17
17
  const diremuckBuff = minion.cardId === "BG27_556_G" ? 4 : 2;
18
- (0, stats_1.modifyStats)(target, diremuckBuff, diremuckBuff, input.playerBoard, input.playerEntity, input.gameState);
19
- input.gameState.spectator.registerPowerTarget(minion, target, input.playerBoard, input.playerEntity, input.opponentEntity);
18
+ (0, stats_1.modifyStats)(target, minion, diremuckBuff, diremuckBuff, input.playerBoard, input.playerEntity, input.gameState);
20
19
  if (input.playerBoard.length < 7) {
21
20
  target.locked = true;
22
21
  const newMinions = (0, deathrattle_spawns_1.spawnEntities)(target.cardId, 1, input.playerBoard, input.playerEntity, input.opponentBoard, input.opponentEntity, input.gameState, minion.friendly, false, false, true, { ...target });
@@ -1 +1 @@
1
- {"version":3,"file":"diremuck-forager.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/diremuck-forager.ts"],"names":[],"mappings":";;;AAAA,iEAAiE;AAEjE,mDAAqD;AACrD,+EAAuE;AACvE,uDAAiE;AAEjE,qDAAwD;AAE3C,QAAA,eAAe,GAAG;IAC9B,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QACvD,MAAM,gBAAgB,GAAG,KAAK,CAAC,YAAY,CAAC,IAAI;aAC9C,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;aACzB,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,WAAC,OAAA,CAAA,MAAA,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,0CAAE,WAAW,EAAE,MAAK,yBAAQ,CAAC,yBAAQ,CAAC,MAAM,CAAC,CAAA,EAAA,CAAC;aAC3G,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QAC3B,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE;YAChC,MAAM,MAAM,GAAG,IAAA,kBAAU,EAAC,gBAAgB,CAAC,CAAC;YAO5C,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,iBAAuC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAClF,IAAA,mBAAW,EAAC,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,YAAY,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;YACxG,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,mBAAmB,CAC5C,MAAM,EACN,MAAM,EACN,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,cAAc,CACpB,CAAC;YAEF,IAAI,KAAK,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;gBACjC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC;gBACrB,MAAM,UAAU,GAAG,IAAA,kCAAa,EAC/B,MAAM,CAAC,MAAM,EACb,CAAC,EACD,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,SAAS,EACf,MAAM,CAAC,QAAQ,EACf,KAAK,EACL,KAAK,EACL,IAAI,EACJ,EAAE,GAAG,MAAM,EAAiB,CAC5B,CAAC;gBACF,KAAK,MAAM,CAAC,IAAI,UAAU,EAAE;oBAC3B,CAAC,CAAC,gBAAgB,GAAG,GAAG,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC;iBACnD;gBACD,IAAA,4BAAmB,EAClB,UAAU,EACV,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,MAAM,EACN,KAAK,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,EAClE,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,SAAS,CACf,CAAC;aACF;SACD;QACD,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, CardType } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { pickRandom } from '../../../services/utils';\r\nimport { spawnEntities } from '../../../simulation/deathrattle-spawns';\r\nimport { performEntitySpawns } from '../../../simulation/spawns';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { modifyStats } from '../../../simulation/stats';\r\n\r\nexport const DiremuckForager = {\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst potentialTargets = input.playerEntity.hand\r\n\t\t\t.filter((e) => !!e.cardId)\r\n\t\t\t.filter((e) => input.gameState.allCards.getCard(e.cardId).type?.toUpperCase() === CardType[CardType.MINION])\r\n\t\t\t.filter((e) => !e.locked);\r\n\t\tif (potentialTargets.length > 0) {\r\n\t\t\tconst target = pickRandom(potentialTargets);\r\n\t\t\t// When it's the opponent, the game state already contains all the buffs\r\n\t\t\t// It can happen that, for the opponent, a card is first added to their hand (eg with Embrace Your Rage)\r\n\t\t\t// and then summoned by Diremuck. In that case, the stats need to be buffed\r\n\t\t\t// Update 29.2 18/04/2024: this is no longer the case, and the minions passed in the initial state should\r\n\t\t\t// reflect the values they have in hand\r\n\t\t\t// if (target?.friendly || !target?.inInitialState) {\r\n\t\t\tconst diremuckBuff = minion.cardId === CardIds.DiremuckForager_BG27_556_G ? 4 : 2;\r\n\t\t\tmodifyStats(target, diremuckBuff, diremuckBuff, input.playerBoard, input.playerEntity, input.gameState);\r\n\t\t\tinput.gameState.spectator.registerPowerTarget(\r\n\t\t\t\tminion,\r\n\t\t\t\ttarget,\r\n\t\t\t\tinput.playerBoard,\r\n\t\t\t\tinput.playerEntity,\r\n\t\t\t\tinput.opponentEntity,\r\n\t\t\t);\r\n\t\t\t// }\r\n\t\t\tif (input.playerBoard.length < 7) {\r\n\t\t\t\ttarget.locked = true;\r\n\t\t\t\tconst newMinions = spawnEntities(\r\n\t\t\t\t\ttarget.cardId,\r\n\t\t\t\t\t1,\r\n\t\t\t\t\tinput.playerBoard,\r\n\t\t\t\t\tinput.playerEntity,\r\n\t\t\t\t\tinput.opponentBoard,\r\n\t\t\t\t\tinput.opponentEntity,\r\n\t\t\t\t\tinput.gameState,\r\n\t\t\t\t\tminion.friendly,\r\n\t\t\t\t\tfalse,\r\n\t\t\t\t\tfalse,\r\n\t\t\t\t\ttrue,\r\n\t\t\t\t\t{ ...target } as BoardEntity,\r\n\t\t\t\t);\r\n\t\t\t\tfor (const s of newMinions) {\r\n\t\t\t\t\ts.onCanceledSummon = () => (target.locked = false);\r\n\t\t\t\t}\r\n\t\t\t\tperformEntitySpawns(\r\n\t\t\t\t\tnewMinions,\r\n\t\t\t\t\tinput.playerBoard,\r\n\t\t\t\t\tinput.playerEntity,\r\n\t\t\t\t\tminion,\r\n\t\t\t\t\tinput.playerBoard.length - (input.playerBoard.indexOf(minion) + 1),\r\n\t\t\t\t\tinput.opponentBoard,\r\n\t\t\t\t\tinput.opponentEntity,\r\n\t\t\t\t\tinput.gameState,\r\n\t\t\t\t);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
1
+ {"version":3,"file":"diremuck-forager.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/diremuck-forager.ts"],"names":[],"mappings":";;;AAAA,iEAAiE;AAEjE,mDAAqD;AACrD,+EAAuE;AACvE,uDAAiE;AAEjE,qDAAwD;AAE3C,QAAA,eAAe,GAAG;IAC9B,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QACvD,MAAM,gBAAgB,GAAG,KAAK,CAAC,YAAY,CAAC,IAAI;aAC9C,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;aACzB,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,WAAC,OAAA,CAAA,MAAA,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,0CAAE,WAAW,EAAE,MAAK,yBAAQ,CAAC,yBAAQ,CAAC,MAAM,CAAC,CAAA,EAAA,CAAC;aAC3G,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QAC3B,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE;YAChC,MAAM,MAAM,GAAG,IAAA,kBAAU,EAAC,gBAAgB,CAAC,CAAC;YAO5C,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,iBAAuC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAClF,IAAA,mBAAW,EACV,MAAM,EACN,MAAM,EACN,YAAY,EACZ,YAAY,EACZ,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,SAAS,CACf,CAAC;YAEF,IAAI,KAAK,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;gBACjC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC;gBACrB,MAAM,UAAU,GAAG,IAAA,kCAAa,EAC/B,MAAM,CAAC,MAAM,EACb,CAAC,EACD,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,SAAS,EACf,MAAM,CAAC,QAAQ,EACf,KAAK,EACL,KAAK,EACL,IAAI,EACJ,EAAE,GAAG,MAAM,EAAiB,CAC5B,CAAC;gBACF,KAAK,MAAM,CAAC,IAAI,UAAU,EAAE;oBAC3B,CAAC,CAAC,gBAAgB,GAAG,GAAG,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC;iBACnD;gBACD,IAAA,4BAAmB,EAClB,UAAU,EACV,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,MAAM,EACN,KAAK,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,EAClE,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,SAAS,CACf,CAAC;aACF;SACD;QACD,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, CardType } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { pickRandom } from '../../../services/utils';\r\nimport { spawnEntities } from '../../../simulation/deathrattle-spawns';\r\nimport { performEntitySpawns } from '../../../simulation/spawns';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { modifyStats } from '../../../simulation/stats';\r\n\r\nexport const DiremuckForager = {\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst potentialTargets = input.playerEntity.hand\r\n\t\t\t.filter((e) => !!e.cardId)\r\n\t\t\t.filter((e) => input.gameState.allCards.getCard(e.cardId).type?.toUpperCase() === CardType[CardType.MINION])\r\n\t\t\t.filter((e) => !e.locked);\r\n\t\tif (potentialTargets.length > 0) {\r\n\t\t\tconst target = pickRandom(potentialTargets);\r\n\t\t\t// When it's the opponent, the game state already contains all the buffs\r\n\t\t\t// It can happen that, for the opponent, a card is first added to their hand (eg with Embrace Your Rage)\r\n\t\t\t// and then summoned by Diremuck. In that case, the stats need to be buffed\r\n\t\t\t// Update 29.2 18/04/2024: this is no longer the case, and the minions passed in the initial state should\r\n\t\t\t// reflect the values they have in hand\r\n\t\t\t// if (target?.friendly || !target?.inInitialState) {\r\n\t\t\tconst diremuckBuff = minion.cardId === CardIds.DiremuckForager_BG27_556_G ? 4 : 2;\r\n\t\t\tmodifyStats(\r\n\t\t\t\ttarget,\r\n\t\t\t\tminion,\r\n\t\t\t\tdiremuckBuff,\r\n\t\t\t\tdiremuckBuff,\r\n\t\t\t\tinput.playerBoard,\r\n\t\t\t\tinput.playerEntity,\r\n\t\t\t\tinput.gameState,\r\n\t\t\t);\r\n\t\t\t// }\r\n\t\t\tif (input.playerBoard.length < 7) {\r\n\t\t\t\ttarget.locked = true;\r\n\t\t\t\tconst newMinions = spawnEntities(\r\n\t\t\t\t\ttarget.cardId,\r\n\t\t\t\t\t1,\r\n\t\t\t\t\tinput.playerBoard,\r\n\t\t\t\t\tinput.playerEntity,\r\n\t\t\t\t\tinput.opponentBoard,\r\n\t\t\t\t\tinput.opponentEntity,\r\n\t\t\t\t\tinput.gameState,\r\n\t\t\t\t\tminion.friendly,\r\n\t\t\t\t\tfalse,\r\n\t\t\t\t\tfalse,\r\n\t\t\t\t\ttrue,\r\n\t\t\t\t\t{ ...target } as BoardEntity,\r\n\t\t\t\t);\r\n\t\t\t\tfor (const s of newMinions) {\r\n\t\t\t\t\ts.onCanceledSummon = () => (target.locked = false);\r\n\t\t\t\t}\r\n\t\t\t\tperformEntitySpawns(\r\n\t\t\t\t\tnewMinions,\r\n\t\t\t\t\tinput.playerBoard,\r\n\t\t\t\t\tinput.playerEntity,\r\n\t\t\t\t\tminion,\r\n\t\t\t\t\tinput.playerBoard.length - (input.playerBoard.indexOf(minion) + 1),\r\n\t\t\t\t\tinput.opponentBoard,\r\n\t\t\t\t\tinput.opponentEntity,\r\n\t\t\t\t\tinput.gameState,\r\n\t\t\t\t);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { AvengeCard } from '../../card.interface';
2
+ export declare const DreamingThornweaver: AvengeCard;
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DreamingThornweaver = void 0;
4
+ exports.DreamingThornweaver = {
5
+ cardIds: ["BG32_433", "BG32_433_G"],
6
+ baseAvengeValue: (cardId) => 4,
7
+ avenge: (minion, input) => {
8
+ const mult = minion.cardId === "BG32_433_G" ? 2 : 1;
9
+ if (minion.scriptDataNum2 === 1) {
10
+ input.hero.globalInfo.BloodGemAttackBonus += 1 * mult;
11
+ }
12
+ else {
13
+ input.hero.globalInfo.BloodGemHealthBonus += 1 * mult;
14
+ }
15
+ },
16
+ };
17
+ //# sourceMappingURL=dreaming-thornweaver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dreaming-thornweaver.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/dreaming-thornweaver.ts"],"names":[],"mappings":";;;AAKa,QAAA,mBAAmB,GAAe;IAC9C,OAAO,EAAE,0BAA8E;IACvF,eAAe,EAAE,CAAC,MAAc,EAAE,EAAE,CAAC,CAAC;IACtC,MAAM,EAAE,CAAC,MAAmB,EAAE,KAAkB,EAAE,EAAE;QACnD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAA2C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9E,IAAI,MAAM,CAAC,cAAc,KAAK,CAAC,EAAE;YAChC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,mBAAmB,IAAI,CAAC,GAAG,IAAI,CAAC;SACtD;aAAM;YACN,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,mBAAmB,IAAI,CAAC,GAAG,IAAI,CAAC;SACtD;IACF,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { AvengeInput } from '../../../simulation/avenge';\r\nimport { AvengeCard } from '../../card.interface';\r\n\r\nexport const DreamingThornweaver: AvengeCard = {\r\n\tcardIds: [CardIds.DreamingThornweaver_BG32_433, CardIds.DreamingThornweaver_BG32_433_G],\r\n\tbaseAvengeValue: (cardId: string) => 4,\r\n\tavenge: (minion: BoardEntity, input: AvengeInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.DreamingThornweaver_BG32_433_G ? 2 : 1;\r\n\t\tif (minion.scriptDataNum2 === 1) {\r\n\t\t\tinput.hero.globalInfo.BloodGemAttackBonus += 1 * mult;\r\n\t\t} else {\r\n\t\t\tinput.hero.globalInfo.BloodGemHealthBonus += 1 * mult;\r\n\t\t}\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { AvengeCard } from '../../card.interface';
2
+ export declare const DrustfallenButcher: AvengeCard;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DrustfallenButcher = void 0;
4
+ const cards_in_hand_1 = require("../../../simulation/cards-in-hand");
5
+ exports.DrustfallenButcher = {
6
+ cardIds: ["BG32_324", "BG32_324_G"],
7
+ baseAvengeValue: (cardId) => 5,
8
+ avenge: (minion, input) => {
9
+ const mult = minion.cardId === "BG32_324_G" ? 2 : 1;
10
+ const cardsToAdd = Array(mult).fill("BG28_604");
11
+ (0, cards_in_hand_1.addCardsInHand)(input.hero, input.board, cardsToAdd, input.gameState);
12
+ },
13
+ };
14
+ //# sourceMappingURL=drustfallen-butcher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"drustfallen-butcher.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/drustfallen-butcher.ts"],"names":[],"mappings":";;;AAGA,qEAAmE;AAGtD,QAAA,kBAAkB,GAAe;IAC7C,OAAO,EAAE,0BAA4E;IACrF,eAAe,EAAE,CAAC,MAAc,EAAE,EAAE,CAAC,CAAC;IACtC,MAAM,EAAE,CAAC,MAAmB,EAAE,KAAkB,EAAE,EAAE;QACnD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAA0C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7E,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,YAA6B,CAAC;QACjE,IAAA,8BAAc,EAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,EAAE,UAAU,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;IACtE,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { AvengeInput } from '../../../simulation/avenge';\r\nimport { addCardsInHand } from '../../../simulation/cards-in-hand';\r\nimport { AvengeCard } from '../../card.interface';\r\n\r\nexport const DrustfallenButcher: AvengeCard = {\r\n\tcardIds: [CardIds.DrustfallenButcher_BG32_324, CardIds.DrustfallenButcher_BG32_324_G],\r\n\tbaseAvengeValue: (cardId: string) => 5,\r\n\tavenge: (minion: BoardEntity, input: AvengeInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.DrustfallenButcher_BG32_324_G ? 2 : 1;\r\n\t\tconst cardsToAdd = Array(mult).fill(CardIds.Butchering_BG28_604);\r\n\t\taddCardsInHand(input.hero, input.board, cardsToAdd, input.gameState);\r\n\t},\r\n};\r\n"]}
@@ -8,8 +8,7 @@ exports.EchoingRoar = {
8
8
  var _a, _b;
9
9
  const enchant = (_a = minion.enchantments) === null || _a === void 0 ? void 0 : _a.find((e) => e.cardId === "BG28_814e");
10
10
  const stats = (_b = enchant === null || enchant === void 0 ? void 0 : enchant.tagScriptDataNum1) !== null && _b !== void 0 ? _b : 1;
11
- (0, stats_1.modifyStats)(minion, 2 * stats, 2 * stats, input.board, input.hero, input.gameState);
12
- input.gameState.spectator.registerPowerTarget(minion, minion, input.board, input.hero, input.otherHero);
11
+ (0, stats_1.modifyStats)(minion, minion, 2 * stats, 2 * stats, input.board, input.hero, input.gameState);
13
12
  },
14
13
  };
15
14
  //# sourceMappingURL=echoing-roar.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"echoing-roar.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/echoing-roar.ts"],"names":[],"mappings":";;;AAEA,qDAAwD;AAG3C,QAAA,WAAW,GAAkB;IACzC,OAAO,EAAE,aAAsD;IAC/D,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAE,EAAE;;QACzD,MAAM,OAAO,GAAG,MAAA,MAAM,CAAC,YAAY,0CAAE,IAAI,CACxC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,gBAAyD,CACxE,CAAC;QACF,MAAM,KAAK,GAAG,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,iBAAiB,mCAAI,CAAC,CAAC;QAC9C,IAAA,mBAAW,EAAC,MAAM,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,GAAG,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QACpF,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;IACzG,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { EndOfTurnCard, EndOfTurnInput } from '../../card.interface';\r\n\r\nexport const EchoingRoar: EndOfTurnCard = {\r\n\tcardIds: [CardIds.EchoingRoar_EchoingRoarEnchantment_BG28_814e],\r\n\tendOfTurn: (minion: BoardEntity, input: EndOfTurnInput) => {\r\n\t\tconst enchant = minion.enchantments?.find(\r\n\t\t\t(e) => e.cardId === CardIds.EchoingRoar_EchoingRoarEnchantment_BG28_814e,\r\n\t\t);\r\n\t\tconst stats = enchant?.tagScriptDataNum1 ?? 1;\r\n\t\tmodifyStats(minion, 2 * stats, 2 * stats, input.board, input.hero, input.gameState);\r\n\t\tinput.gameState.spectator.registerPowerTarget(minion, minion, input.board, input.hero, input.otherHero);\r\n\t},\r\n};\r\n"]}
1
+ {"version":3,"file":"echoing-roar.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/echoing-roar.ts"],"names":[],"mappings":";;;AAEA,qDAAwD;AAG3C,QAAA,WAAW,GAAkB;IACzC,OAAO,EAAE,aAAsD;IAC/D,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAE,EAAE;;QACzD,MAAM,OAAO,GAAG,MAAA,MAAM,CAAC,YAAY,0CAAE,IAAI,CACxC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,gBAAyD,CACxE,CAAC;QACF,MAAM,KAAK,GAAG,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,iBAAiB,mCAAI,CAAC,CAAC;QAC9C,IAAA,mBAAW,EAAC,MAAM,EAAE,MAAM,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,GAAG,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;IAC7F,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { EndOfTurnCard, EndOfTurnInput } from '../../card.interface';\r\n\r\nexport const EchoingRoar: EndOfTurnCard = {\r\n\tcardIds: [CardIds.EchoingRoar_EchoingRoarEnchantment_BG28_814e],\r\n\tendOfTurn: (minion: BoardEntity, input: EndOfTurnInput) => {\r\n\t\tconst enchant = minion.enchantments?.find(\r\n\t\t\t(e) => e.cardId === CardIds.EchoingRoar_EchoingRoarEnchantment_BG28_814e,\r\n\t\t);\r\n\t\tconst stats = enchant?.tagScriptDataNum1 ?? 1;\r\n\t\tmodifyStats(minion, minion, 2 * stats, 2 * stats, input.board, input.hero, input.gameState);\r\n\t},\r\n};\r\n"]}
@@ -8,6 +8,7 @@ const _card_mappings_1 = require("../_card-mappings");
8
8
  exports.EfficientEngineer = {
9
9
  cardIds: ["BG31_301", "BG31_301_G"],
10
10
  battlecry: (minion, input) => {
11
+ var _a, _b;
11
12
  const mult = minion.cardId === "BG31_301_G" ? 2 : 1;
12
13
  const allCards = input.gameState.allCards;
13
14
  for (let i = 0; i < mult; i++) {
@@ -21,11 +22,14 @@ exports.EfficientEngineer = {
21
22
  for (const cardId of endOfTurnCandidates) {
22
23
  const endOfTurnImpl = _card_mappings_1.cardMappings[cardId];
23
24
  if ((0, card_interface_1.hasEndOfTurn)(endOfTurnImpl)) {
24
- const numberOfLoops = input.board.some((e) => e.cardId === "BG26_ICC_901_G")
25
+ const baseLoops = 1 +
26
+ ((_b = (_a = input.hero.trinkets) === null || _a === void 0 ? void 0 : _a.filter((t) => t.cardId === "BG32_MagicItem_367").length) !== null && _b !== void 0 ? _b : 0);
27
+ const minionLoops = input.board.some((e) => e.cardId === "BG26_ICC_901_G")
25
28
  ? 3
26
29
  : input.board.some((e) => e.cardId === "BG26_ICC_901")
27
30
  ? 2
28
31
  : 1;
32
+ const numberOfLoops = baseLoops * minionLoops;
29
33
  for (let i = 0; i < numberOfLoops; i++) {
30
34
  endOfTurnImpl.endOfTurn(target, input);
31
35
  }
@@ -33,6 +37,7 @@ exports.EfficientEngineer = {
33
37
  }
34
38
  }
35
39
  }
40
+ return true;
36
41
  },
37
42
  };
38
43
  const hasEndOfTurnMechanics = (cardId, allCards) => {
@@ -1 +1 @@
1
- {"version":3,"file":"efficient-engineer.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/efficient-engineer.ts"],"names":[],"mappings":";;;AAAA,iEAAiF;AAEjF,mDAAqD;AAErD,yDAAmE;AACnE,sDAAiD;AAEpC,QAAA,iBAAiB,GAAkB;IAC/C,OAAO,EAAE,0BAA0E;IACnF,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAE,EAAE;QACzD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAAyC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5E,MAAM,QAAQ,GAAG,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC;QAC1C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC9B,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK;iBAC5B,MAAM,CACN,CAAC,CAAC,EAAE,EAAE,CACL,CAAC,0BAAgE,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAiB,CAAC,CAChG;iBACA,MAAM,CACN,CAAC,CAAC,EAAE,EAAE,CACL,qBAAqB,CAAC,CAAC,CAAC,MAAM,EAAE,QAAQ,CAAC;gBACzC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CACtE,CAAC;YACH,MAAM,MAAM,GAAG,IAAA,kBAAU,EAAC,UAAU,CAAC,CAAC;YACtC,IAAI,MAAM,EAAE;gBACX,MAAM,mBAAmB,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,MAAM,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CACrG,qBAAqB,CAAC,CAAC,EAAE,QAAQ,CAAC,CAClC,CAAC;gBACF,KAAK,MAAM,MAAM,IAAI,mBAAmB,EAAE;oBACzC,MAAM,aAAa,GAAG,6BAAY,CAAC,MAAM,CAAC,CAAC;oBAC3C,IAAI,IAAA,6BAAY,EAAC,aAAa,CAAC,EAAE;wBAChC,MAAM,aAAa,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CACrC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,qBAA6C,CAC5D;4BACA,CAAC,CAAC,CAAC;4BACH,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,mBAA2C,CAAC;gCAC9E,CAAC,CAAC,CAAC;gCACH,CAAC,CAAC,CAAC,CAAC;wBACL,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,EAAE,CAAC,EAAE,EAAE;4BACvC,aAAa,CAAC,SAAS,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;yBACvC;qBACD;iBACD;aACD;SACD;IACF,CAAC;CACD,CAAC;AAEF,MAAM,qBAAqB,GAAG,CAAC,MAAc,EAAE,QAAyB,EAAW,EAAE;;IACpF,OAAO,MAAA,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,SAAS,0CAAE,QAAQ,CAAC,wBAAO,CAAC,wBAAO,CAAC,WAAW,CAAC,CAAC,CAAC;AACnF,CAAC,CAAC","sourcesContent":["import { AllCardsService, CardIds, GameTag } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { pickRandom } from '../../../services/utils';\r\nimport { BattlecryInput } from '../../../simulation/battlecries';\r\nimport { BattlecryCard, hasEndOfTurn } from '../../card.interface';\r\nimport { cardMappings } from '../_card-mappings';\r\n\r\nexport const EfficientEngineer: BattlecryCard = {\r\n\tcardIds: [CardIds.EfficientEngineer_BG31_301, CardIds.EfficientEngineer_BG31_301_G],\r\n\tbattlecry: (minion: BoardEntity, input: BattlecryInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.EfficientEngineer_BG31_301_G ? 2 : 1;\r\n\t\tconst allCards = input.gameState.allCards;\r\n\t\tfor (let i = 0; i < mult; i++) {\r\n\t\t\tconst candidates = input.board\r\n\t\t\t\t.filter(\r\n\t\t\t\t\t(e) =>\r\n\t\t\t\t\t\t![CardIds.YoungMurkEye_BG22_403, CardIds.YoungMurkEye_BG22_403_G].includes(e.cardId as CardIds),\r\n\t\t\t\t)\r\n\t\t\t\t.filter(\r\n\t\t\t\t\t(m) =>\r\n\t\t\t\t\t\thasEndOfTurnMechanics(m.cardId, allCards) ||\r\n\t\t\t\t\t\tm.enchantments.some((e) => hasEndOfTurnMechanics(e.cardId, allCards)),\r\n\t\t\t\t);\r\n\t\t\tconst target = pickRandom(candidates);\r\n\t\t\tif (target) {\r\n\t\t\t\tconst endOfTurnCandidates = [target.cardId, ...target.enchantments.map((e) => e.cardId)].filter((e) =>\r\n\t\t\t\t\thasEndOfTurnMechanics(e, allCards),\r\n\t\t\t\t);\r\n\t\t\t\tfor (const cardId of endOfTurnCandidates) {\r\n\t\t\t\t\tconst endOfTurnImpl = cardMappings[cardId];\r\n\t\t\t\t\tif (hasEndOfTurn(endOfTurnImpl)) {\r\n\t\t\t\t\t\tconst numberOfLoops = input.board.some(\r\n\t\t\t\t\t\t\t(e) => e.cardId === CardIds.DrakkariEnchanter_BG26_ICC_901_G,\r\n\t\t\t\t\t\t)\r\n\t\t\t\t\t\t\t? 3\r\n\t\t\t\t\t\t\t: input.board.some((e) => e.cardId === CardIds.DrakkariEnchanter_BG26_ICC_901)\r\n\t\t\t\t\t\t\t? 2\r\n\t\t\t\t\t\t\t: 1;\r\n\t\t\t\t\t\tfor (let i = 0; i < numberOfLoops; i++) {\r\n\t\t\t\t\t\t\tendOfTurnImpl.endOfTurn(target, input);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t},\r\n};\r\n\r\nconst hasEndOfTurnMechanics = (cardId: string, allCards: AllCardsService): boolean => {\r\n\treturn allCards.getCard(cardId).mechanics?.includes(GameTag[GameTag.END_OF_TURN]);\r\n};\r\n"]}
1
+ {"version":3,"file":"efficient-engineer.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/efficient-engineer.ts"],"names":[],"mappings":";;;AAAA,iEAAiF;AAEjF,mDAAqD;AAErD,yDAAmE;AACnE,sDAAiD;AAEpC,QAAA,iBAAiB,GAAkB;IAC/C,OAAO,EAAE,0BAA0E;IACnF,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAE,EAAE;;QACzD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAAyC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5E,MAAM,QAAQ,GAAG,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC;QAC1C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC9B,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK;iBAC5B,MAAM,CACN,CAAC,CAAC,EAAE,EAAE,CACL,CAAC,0BAAgE,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAiB,CAAC,CAChG;iBACA,MAAM,CACN,CAAC,CAAC,EAAE,EAAE,CACL,qBAAqB,CAAC,CAAC,CAAC,MAAM,EAAE,QAAQ,CAAC;gBACzC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CACtE,CAAC;YACH,MAAM,MAAM,GAAG,IAAA,kBAAU,EAAC,UAAU,CAAC,CAAC;YACtC,IAAI,MAAM,EAAE;gBACX,MAAM,mBAAmB,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,MAAM,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CACrG,qBAAqB,CAAC,CAAC,EAAE,QAAQ,CAAC,CAClC,CAAC;gBACF,KAAK,MAAM,MAAM,IAAI,mBAAmB,EAAE;oBACzC,MAAM,aAAa,GAAG,6BAAY,CAAC,MAAM,CAAC,CAAC;oBAC3C,IAAI,IAAA,6BAAY,EAAC,aAAa,CAAC,EAAE;wBAChC,MAAM,SAAS,GACd,CAAC;4BACD,CAAC,MAAA,MAAA,KAAK,CAAC,IAAI,CAAC,QAAQ,0CAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,yBAA8C,EACxF,MAAM,mCAAI,CAAC,CAAC,CAAC;wBAChB,MAAM,WAAW,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CACnC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,qBAA6C,CAC5D;4BACA,CAAC,CAAC,CAAC;4BACH,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,mBAA2C,CAAC;gCAC9E,CAAC,CAAC,CAAC;gCACH,CAAC,CAAC,CAAC,CAAC;wBACL,MAAM,aAAa,GAAG,SAAS,GAAG,WAAW,CAAC;wBAC9C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,EAAE,CAAC,EAAE,EAAE;4BACvC,aAAa,CAAC,SAAS,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;yBACvC;qBACD;iBACD;aACD;SACD;QACD,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC;AAEF,MAAM,qBAAqB,GAAG,CAAC,MAAc,EAAE,QAAyB,EAAW,EAAE;;IACpF,OAAO,MAAA,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,SAAS,0CAAE,QAAQ,CAAC,wBAAO,CAAC,wBAAO,CAAC,WAAW,CAAC,CAAC,CAAC;AACnF,CAAC,CAAC","sourcesContent":["import { AllCardsService, CardIds, GameTag } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { pickRandom } from '../../../services/utils';\r\nimport { BattlecryInput } from '../../../simulation/battlecries';\r\nimport { BattlecryCard, hasEndOfTurn } from '../../card.interface';\r\nimport { cardMappings } from '../_card-mappings';\r\n\r\nexport const EfficientEngineer: BattlecryCard = {\r\n\tcardIds: [CardIds.EfficientEngineer_BG31_301, CardIds.EfficientEngineer_BG31_301_G],\r\n\tbattlecry: (minion: BoardEntity, input: BattlecryInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.EfficientEngineer_BG31_301_G ? 2 : 1;\r\n\t\tconst allCards = input.gameState.allCards;\r\n\t\tfor (let i = 0; i < mult; i++) {\r\n\t\t\tconst candidates = input.board\r\n\t\t\t\t.filter(\r\n\t\t\t\t\t(e) =>\r\n\t\t\t\t\t\t![CardIds.YoungMurkEye_BG22_403, CardIds.YoungMurkEye_BG22_403_G].includes(e.cardId as CardIds),\r\n\t\t\t\t)\r\n\t\t\t\t.filter(\r\n\t\t\t\t\t(m) =>\r\n\t\t\t\t\t\thasEndOfTurnMechanics(m.cardId, allCards) ||\r\n\t\t\t\t\t\tm.enchantments.some((e) => hasEndOfTurnMechanics(e.cardId, allCards)),\r\n\t\t\t\t);\r\n\t\t\tconst target = pickRandom(candidates);\r\n\t\t\tif (target) {\r\n\t\t\t\tconst endOfTurnCandidates = [target.cardId, ...target.enchantments.map((e) => e.cardId)].filter((e) =>\r\n\t\t\t\t\thasEndOfTurnMechanics(e, allCards),\r\n\t\t\t\t);\r\n\t\t\t\tfor (const cardId of endOfTurnCandidates) {\r\n\t\t\t\t\tconst endOfTurnImpl = cardMappings[cardId];\r\n\t\t\t\t\tif (hasEndOfTurn(endOfTurnImpl)) {\r\n\t\t\t\t\t\tconst baseLoops =\r\n\t\t\t\t\t\t\t1 +\r\n\t\t\t\t\t\t\t(input.hero.trinkets?.filter((t) => t.cardId === CardIds.GhastlySticker_BG32_MagicItem_367)\r\n\t\t\t\t\t\t\t\t.length ?? 0);\r\n\t\t\t\t\t\tconst minionLoops = input.board.some(\r\n\t\t\t\t\t\t\t(e) => e.cardId === CardIds.DrakkariEnchanter_BG26_ICC_901_G,\r\n\t\t\t\t\t\t)\r\n\t\t\t\t\t\t\t? 3\r\n\t\t\t\t\t\t\t: input.board.some((e) => e.cardId === CardIds.DrakkariEnchanter_BG26_ICC_901)\r\n\t\t\t\t\t\t\t? 2\r\n\t\t\t\t\t\t\t: 1;\r\n\t\t\t\t\t\tconst numberOfLoops = baseLoops * minionLoops;\r\n\t\t\t\t\t\tfor (let i = 0; i < numberOfLoops; i++) {\r\n\t\t\t\t\t\t\tendOfTurnImpl.endOfTurn(target, input);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn true;\r\n\t},\r\n};\r\n\r\nconst hasEndOfTurnMechanics = (cardId: string, allCards: AllCardsService): boolean => {\r\n\treturn allCards.getCard(cardId).mechanics?.includes(GameTag[GameTag.END_OF_TURN]);\r\n};\r\n"]}
@@ -10,8 +10,7 @@ exports.ElderTaggawag = {
10
10
  const highestAttackOnBoard = Math.max(...input.playerBoard.map((entity) => entity.attack));
11
11
  const highestHealthOnBoard = Math.max(...input.playerBoard.map((entity) => entity.health));
12
12
  const multiplier = minion.cardId === "TB_BaconShop_HERO_14_Buddy_G" ? 2 : 1;
13
- (0, stats_1.modifyStats)(minion, highestAttackOnBoard * multiplier, highestHealthOnBoard * multiplier, input.playerBoard, input.playerEntity, input.gameState);
14
- input.gameState.spectator.registerPowerTarget(minion, minion, input.playerBoard, input.playerEntity, input.opponentEntity);
13
+ (0, stats_1.modifyStats)(minion, minion, highestAttackOnBoard * multiplier, highestHealthOnBoard * multiplier, input.playerBoard, input.playerEntity, input.gameState);
15
14
  }
16
15
  return true;
17
16
  },
@@ -1 +1 @@
1
- {"version":3,"file":"elder-taggawag.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/elder-taggawag.ts"],"names":[],"mappings":";;;AAGA,qDAAwD;AACxD,0CAA4D;AAE/C,QAAA,aAAa,GAAG;IAC5B,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QACvD,MAAM,uBAAuB,GAAG,IAAA,kCAA0B,EACzD,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,SAAS,CACf,CAAC;QACF,IAAI,uBAAuB,CAAC,MAAM,IAAI,CAAC,EAAE;YACxC,MAAM,oBAAoB,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;YAC3F,MAAM,oBAAoB,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;YAC3F,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,mCAAuD,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAChG,IAAA,mBAAW,EACV,MAAM,EACN,oBAAoB,GAAG,UAAU,EACjC,oBAAoB,GAAG,UAAU,EACjC,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,SAAS,CACf,CAAC;YACF,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,mBAAmB,CAC5C,MAAM,EACN,MAAM,EACN,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,cAAc,CACpB,CAAC;SACF;QACD,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { getMinionsOfDifferentTypes } from '../../../utils';\r\n\r\nexport const ElderTaggawag = {\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst minionsOfDifferentTypes = getMinionsOfDifferentTypes(\r\n\t\t\tinput.playerBoard,\r\n\t\t\tinput.playerEntity,\r\n\t\t\tinput.gameState,\r\n\t\t);\r\n\t\tif (minionsOfDifferentTypes.length >= 4) {\r\n\t\t\tconst highestAttackOnBoard = Math.max(...input.playerBoard.map((entity) => entity.attack));\r\n\t\t\tconst highestHealthOnBoard = Math.max(...input.playerBoard.map((entity) => entity.health));\r\n\t\t\tconst multiplier = minion.cardId === CardIds.ElderTaggawag_TB_BaconShop_HERO_14_Buddy_G ? 2 : 1;\r\n\t\t\tmodifyStats(\r\n\t\t\t\tminion,\r\n\t\t\t\thighestAttackOnBoard * multiplier,\r\n\t\t\t\thighestHealthOnBoard * multiplier,\r\n\t\t\t\tinput.playerBoard,\r\n\t\t\t\tinput.playerEntity,\r\n\t\t\t\tinput.gameState,\r\n\t\t\t);\r\n\t\t\tinput.gameState.spectator.registerPowerTarget(\r\n\t\t\t\tminion,\r\n\t\t\t\tminion,\r\n\t\t\t\tinput.playerBoard,\r\n\t\t\t\tinput.playerEntity,\r\n\t\t\t\tinput.opponentEntity,\r\n\t\t\t);\r\n\t\t}\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
1
+ {"version":3,"file":"elder-taggawag.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/elder-taggawag.ts"],"names":[],"mappings":";;;AAGA,qDAAwD;AACxD,0CAA4D;AAE/C,QAAA,aAAa,GAAG;IAC5B,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QACvD,MAAM,uBAAuB,GAAG,IAAA,kCAA0B,EACzD,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,SAAS,CACf,CAAC;QACF,IAAI,uBAAuB,CAAC,MAAM,IAAI,CAAC,EAAE;YACxC,MAAM,oBAAoB,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;YAC3F,MAAM,oBAAoB,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;YAC3F,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,mCAAuD,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAChG,IAAA,mBAAW,EACV,MAAM,EACN,MAAM,EACN,oBAAoB,GAAG,UAAU,EACjC,oBAAoB,GAAG,UAAU,EACjC,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,SAAS,CACf,CAAC;SACF;QACD,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { getMinionsOfDifferentTypes } from '../../../utils';\r\n\r\nexport const ElderTaggawag = {\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst minionsOfDifferentTypes = getMinionsOfDifferentTypes(\r\n\t\t\tinput.playerBoard,\r\n\t\t\tinput.playerEntity,\r\n\t\t\tinput.gameState,\r\n\t\t);\r\n\t\tif (minionsOfDifferentTypes.length >= 4) {\r\n\t\t\tconst highestAttackOnBoard = Math.max(...input.playerBoard.map((entity) => entity.attack));\r\n\t\t\tconst highestHealthOnBoard = Math.max(...input.playerBoard.map((entity) => entity.health));\r\n\t\t\tconst multiplier = minion.cardId === CardIds.ElderTaggawag_TB_BaconShop_HERO_14_Buddy_G ? 2 : 1;\r\n\t\t\tmodifyStats(\r\n\t\t\t\tminion,\r\n\t\t\t\tminion,\r\n\t\t\t\thighestAttackOnBoard * multiplier,\r\n\t\t\t\thighestHealthOnBoard * multiplier,\r\n\t\t\t\tinput.playerBoard,\r\n\t\t\t\tinput.playerEntity,\r\n\t\t\t\tinput.gameState,\r\n\t\t\t);\r\n\t\t}\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
@@ -12,7 +12,7 @@ exports.ElectricSynthesizer = {
12
12
  .filter((e) => e.entityId !== minion.entityId);
13
13
  const buff = minion.cardId === "BG26_963_G" ? 2 : 1;
14
14
  for (const entity of otherDragons) {
15
- (0, stats_1.modifyStats)(entity, buff, buff, input.playerBoard, input.playerEntity, input.gameState);
15
+ (0, stats_1.modifyStats)(entity, minion, buff, buff, input.playerBoard, input.playerEntity, input.gameState);
16
16
  }
17
17
  return true;
18
18
  },
@@ -22,8 +22,9 @@ exports.ElectricSynthesizer = {
22
22
  .filter((e) => e.entityId !== minion.entityId);
23
23
  const buff = minion.cardId === "BG26_963_G" ? 2 : 1;
24
24
  for (const entity of otherDragons) {
25
- (0, stats_1.modifyStats)(entity, buff, buff, input.board, input.hero, input.gameState);
25
+ (0, stats_1.modifyStats)(entity, minion, buff, buff, input.board, input.hero, input.gameState);
26
26
  }
27
+ return true;
27
28
  },
28
29
  };
29
30
  //# sourceMappingURL=electric-synthesizer.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"electric-synthesizer.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/electric-synthesizer.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAI7D,qDAAwD;AACxD,0CAAiD;AAGpC,QAAA,mBAAmB,GAAsC;IACrE,OAAO,EAAE,0BAA8E;IACvF,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QACvD,MAAM,YAAY,GAAG,KAAK,CAAC,WAAW;aACpC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CACb,IAAA,uBAAe,EACd,CAAC,EACD,KAAK,CAAC,YAAY,EAClB,qBAAI,CAAC,MAAM,EACX,KAAK,CAAC,SAAS,CAAC,SAAS,EACzB,KAAK,CAAC,SAAS,CAAC,QAAQ,CACxB,CACD;aACA,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC;QAChD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAA2C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9E,KAAK,MAAM,MAAM,IAAI,YAAY,EAAE;YAClC,IAAA,mBAAW,EAAC,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,YAAY,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;SACxF;QACD,OAAO,IAAI,CAAC;IACb,CAAC;IACD,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAE,EAAE;QACzD,MAAM,YAAY,GAAG,KAAK,CAAC,KAAK;aAC9B,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CACb,IAAA,uBAAe,EAAC,CAAC,EAAE,KAAK,CAAC,IAAI,EAAE,qBAAI,CAAC,MAAM,EAAE,KAAK,CAAC,SAAS,CAAC,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAChG;aACA,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC;QAChD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAA2C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9E,KAAK,MAAM,MAAM,IAAI,YAAY,EAAE;YAClC,IAAA,mBAAW,EAAC,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;SAC1E;IACF,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, Race } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { BattlecryInput } from '../../../simulation/battlecries';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { hasCorrectTribe } from '../../../utils';\r\nimport { BattlecryCard, StartOfCombatCard } from '../../card.interface';\r\n\r\nexport const ElectricSynthesizer: StartOfCombatCard & BattlecryCard = {\r\n\tcardIds: [CardIds.ElectricSynthesizer_BG26_963, CardIds.ElectricSynthesizer_BG26_963_G],\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst otherDragons = input.playerBoard\r\n\t\t\t.filter((e) =>\r\n\t\t\t\thasCorrectTribe(\r\n\t\t\t\t\te,\r\n\t\t\t\t\tinput.playerEntity,\r\n\t\t\t\t\tRace.DRAGON,\r\n\t\t\t\t\tinput.gameState.anomalies,\r\n\t\t\t\t\tinput.gameState.allCards,\r\n\t\t\t\t),\r\n\t\t\t)\r\n\t\t\t.filter((e) => e.entityId !== minion.entityId);\r\n\t\tconst buff = minion.cardId === CardIds.ElectricSynthesizer_BG26_963_G ? 2 : 1;\r\n\t\tfor (const entity of otherDragons) {\r\n\t\t\tmodifyStats(entity, buff, buff, input.playerBoard, input.playerEntity, input.gameState);\r\n\t\t}\r\n\t\treturn true;\r\n\t},\r\n\tbattlecry: (minion: BoardEntity, input: BattlecryInput) => {\r\n\t\tconst otherDragons = input.board\r\n\t\t\t.filter((e) =>\r\n\t\t\t\thasCorrectTribe(e, input.hero, Race.DRAGON, input.gameState.anomalies, input.gameState.allCards),\r\n\t\t\t)\r\n\t\t\t.filter((e) => e.entityId !== minion.entityId);\r\n\t\tconst buff = minion.cardId === CardIds.ElectricSynthesizer_BG26_963_G ? 2 : 1;\r\n\t\tfor (const entity of otherDragons) {\r\n\t\t\tmodifyStats(entity, buff, buff, input.board, input.hero, input.gameState);\r\n\t\t}\r\n\t},\r\n};\r\n"]}
1
+ {"version":3,"file":"electric-synthesizer.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/electric-synthesizer.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAI7D,qDAAwD;AACxD,0CAAiD;AAGpC,QAAA,mBAAmB,GAAsC;IACrE,OAAO,EAAE,0BAA8E;IACvF,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QACvD,MAAM,YAAY,GAAG,KAAK,CAAC,WAAW;aACpC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CACb,IAAA,uBAAe,EACd,CAAC,EACD,KAAK,CAAC,YAAY,EAClB,qBAAI,CAAC,MAAM,EACX,KAAK,CAAC,SAAS,CAAC,SAAS,EACzB,KAAK,CAAC,SAAS,CAAC,QAAQ,CACxB,CACD;aACA,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC;QAChD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAA2C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9E,KAAK,MAAM,MAAM,IAAI,YAAY,EAAE;YAClC,IAAA,mBAAW,EAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,YAAY,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;SAChG;QACD,OAAO,IAAI,CAAC;IACb,CAAC;IACD,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAE,EAAE;QACzD,MAAM,YAAY,GAAG,KAAK,CAAC,KAAK;aAC9B,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CACb,IAAA,uBAAe,EAAC,CAAC,EAAE,KAAK,CAAC,IAAI,EAAE,qBAAI,CAAC,MAAM,EAAE,KAAK,CAAC,SAAS,CAAC,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAChG;aACA,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC;QAChD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAA2C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9E,KAAK,MAAM,MAAM,IAAI,YAAY,EAAE;YAClC,IAAA,mBAAW,EAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;SAClF;QACD,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, Race } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { BattlecryInput } from '../../../simulation/battlecries';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { hasCorrectTribe } from '../../../utils';\r\nimport { BattlecryCard, StartOfCombatCard } from '../../card.interface';\r\n\r\nexport const ElectricSynthesizer: StartOfCombatCard & BattlecryCard = {\r\n\tcardIds: [CardIds.ElectricSynthesizer_BG26_963, CardIds.ElectricSynthesizer_BG26_963_G],\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst otherDragons = input.playerBoard\r\n\t\t\t.filter((e) =>\r\n\t\t\t\thasCorrectTribe(\r\n\t\t\t\t\te,\r\n\t\t\t\t\tinput.playerEntity,\r\n\t\t\t\t\tRace.DRAGON,\r\n\t\t\t\t\tinput.gameState.anomalies,\r\n\t\t\t\t\tinput.gameState.allCards,\r\n\t\t\t\t),\r\n\t\t\t)\r\n\t\t\t.filter((e) => e.entityId !== minion.entityId);\r\n\t\tconst buff = minion.cardId === CardIds.ElectricSynthesizer_BG26_963_G ? 2 : 1;\r\n\t\tfor (const entity of otherDragons) {\r\n\t\t\tmodifyStats(entity, minion, buff, buff, input.playerBoard, input.playerEntity, input.gameState);\r\n\t\t}\r\n\t\treturn true;\r\n\t},\r\n\tbattlecry: (minion: BoardEntity, input: BattlecryInput) => {\r\n\t\tconst otherDragons = input.board\r\n\t\t\t.filter((e) =>\r\n\t\t\t\thasCorrectTribe(e, input.hero, Race.DRAGON, input.gameState.anomalies, input.gameState.allCards),\r\n\t\t\t)\r\n\t\t\t.filter((e) => e.entityId !== minion.entityId);\r\n\t\tconst buff = minion.cardId === CardIds.ElectricSynthesizer_BG26_963_G ? 2 : 1;\r\n\t\tfor (const entity of otherDragons) {\r\n\t\t\tmodifyStats(entity, minion, buff, buff, input.board, input.hero, input.gameState);\r\n\t\t}\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { BattlecryCard } from '../../card.interface';
2
+ export declare const EliteNavigator: BattlecryCard;
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EliteNavigator = void 0;
4
+ const reference_data_1 = require("@firestone-hs/reference-data");
5
+ const golden_1 = require("../../../simulation/utils/golden");
6
+ const utils_1 = require("../../../utils");
7
+ exports.EliteNavigator = {
8
+ cardIds: ["BG32_231", "BG32_231_G"],
9
+ battlecry: (minion, input) => {
10
+ const mult = minion.cardId === "BG32_231_G" ? 2 : 1;
11
+ for (let i = 0; i < mult; i++) {
12
+ const candidates = input.board
13
+ .filter((e) => (0, utils_1.hasCorrectTribe)(e, input.hero, reference_data_1.Race.PIRATE, input.gameState.anomalies, input.gameState.allCards))
14
+ .filter((e) => input.gameState.allCards.getCard(e.cardId).techLevel >= 4)
15
+ .filter((e) => !(0, utils_1.isGolden)(e.cardId, input.gameState.allCards));
16
+ const target = candidates[0];
17
+ if (!!target) {
18
+ (0, golden_1.makeMinionGolden)(target, minion, input.board, input.hero, input.otherBoard, input.otherHero, input.gameState);
19
+ }
20
+ }
21
+ return true;
22
+ },
23
+ };
24
+ //# sourceMappingURL=elite-navigator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"elite-navigator.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/elite-navigator.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAG7D,6DAAoE;AACpE,0CAA2D;AAG9C,QAAA,cAAc,GAAkB;IAC5C,OAAO,EAAE,0BAAoE;IAC7E,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAE,EAAE;QACzD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAAsC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACzE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC9B,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK;iBAC5B,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CACb,IAAA,uBAAe,EAAC,CAAC,EAAE,KAAK,CAAC,IAAI,EAAE,qBAAI,CAAC,MAAM,EAAE,KAAK,CAAC,SAAS,CAAC,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAChG;iBACA,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,SAAS,IAAI,CAAC,CAAC;iBACxE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAA,gBAAQ,EAAC,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;YAC/D,MAAM,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;YAC7B,IAAI,CAAC,CAAC,MAAM,EAAE;gBACb,IAAA,yBAAgB,EACf,MAAM,EACN,MAAM,EACN,KAAK,CAAC,KAAK,EACX,KAAK,CAAC,IAAI,EACV,KAAK,CAAC,UAAU,EAChB,KAAK,CAAC,SAAS,EACf,KAAK,CAAC,SAAS,CACf,CAAC;aACF;SACD;QACD,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, Race } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { BattlecryInput } from '../../../simulation/battlecries';\r\nimport { makeMinionGolden } from '../../../simulation/utils/golden';\r\nimport { hasCorrectTribe, isGolden } from '../../../utils';\r\nimport { BattlecryCard } from '../../card.interface';\r\n\r\nexport const EliteNavigator: BattlecryCard = {\r\n\tcardIds: [CardIds.EliteNavigator_BG32_231, CardIds.EliteNavigator_BG32_231_G],\r\n\tbattlecry: (minion: BoardEntity, input: BattlecryInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.EliteNavigator_BG32_231_G ? 2 : 1;\r\n\t\tfor (let i = 0; i < mult; i++) {\r\n\t\t\tconst candidates = input.board\r\n\t\t\t\t.filter((e) =>\r\n\t\t\t\t\thasCorrectTribe(e, input.hero, Race.PIRATE, input.gameState.anomalies, input.gameState.allCards),\r\n\t\t\t\t)\r\n\t\t\t\t.filter((e) => input.gameState.allCards.getCard(e.cardId).techLevel >= 4)\r\n\t\t\t\t.filter((e) => !isGolden(e.cardId, input.gameState.allCards));\r\n\t\t\tconst target = candidates[0];\r\n\t\t\tif (!!target) {\r\n\t\t\t\tmakeMinionGolden(\r\n\t\t\t\t\ttarget,\r\n\t\t\t\t\tminion,\r\n\t\t\t\t\tinput.board,\r\n\t\t\t\t\tinput.hero,\r\n\t\t\t\t\tinput.otherBoard,\r\n\t\t\t\t\tinput.otherHero,\r\n\t\t\t\t\tinput.gameState,\r\n\t\t\t\t);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { EndOfTurnCard } from '../../card.interface';
2
+ export declare const FaunaWhisperer: EndOfTurnCard;
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FaunaWhisperer = void 0;
4
+ const reference_data_1 = require("@firestone-hs/reference-data");
5
+ const stats_1 = require("../../../simulation/stats");
6
+ const wax_warband_1 = require("../hero-power/wax-warband");
7
+ exports.FaunaWhisperer = {
8
+ cardIds: ["BG32_837", "BG32_837_G"],
9
+ endOfTurn: (minion, input) => {
10
+ var _a;
11
+ const index = input.board.indexOf(minion);
12
+ if (index === 0) {
13
+ return;
14
+ }
15
+ const targets = [];
16
+ targets.push(input.board[index - 1]);
17
+ if (minion.cardId === "BG32_837_G" && index < input.board.length - 1) {
18
+ targets.push(input.board[index + 1]);
19
+ }
20
+ for (const target of targets) {
21
+ const targetRaces = ((_a = input.gameState.allCards.getCard(target.cardId).races) !== null && _a !== void 0 ? _a : []).map((r) => reference_data_1.Race[r]);
22
+ const spellTargets = (0, wax_warband_1.selectMinions)(input.board, targetRaces, input.gameState.allCards);
23
+ for (const spellTarget of spellTargets) {
24
+ (0, stats_1.modifyStats)(spellTarget, minion, 2, 2, input.board, input.hero, input.gameState);
25
+ }
26
+ }
27
+ },
28
+ };
29
+ //# sourceMappingURL=fauna-whisperer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fauna-whisperer.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/fauna-whisperer.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAE7D,qDAAwD;AAExD,2DAA0D;AAE7C,QAAA,cAAc,GAAkB;IAC5C,OAAO,EAAE,0BAAoE;IAC7E,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAE,EAAE;;QACzD,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAC1C,IAAI,KAAK,KAAK,CAAC,EAAE;YAChB,OAAO;SACP;QACD,MAAM,OAAO,GAAkB,EAAE,CAAC;QAClC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;QAErC,IAAI,MAAM,CAAC,MAAM,iBAAsC,IAAI,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YAC1F,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;SACrC;QAED,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;YAC7B,MAAM,WAAW,GAAG,CAAC,MAAA,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,mCAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,qBAAI,CAAC,CAAC,CAAC,CAAC,CAAC;YACtG,MAAM,YAAY,GAAG,IAAA,2BAAa,EAAC,KAAK,CAAC,KAAK,EAAE,WAAW,EAAE,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;YACvF,KAAK,MAAM,WAAW,IAAI,YAAY,EAAE;gBACvC,IAAA,mBAAW,EAAC,WAAW,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;aACjF;SACD;IACF,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, Race } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { EndOfTurnCard, EndOfTurnInput } from '../../card.interface';\r\nimport { selectMinions } from '../hero-power/wax-warband';\r\n\r\nexport const FaunaWhisperer: EndOfTurnCard = {\r\n\tcardIds: [CardIds.FaunaWhisperer_BG32_837, CardIds.FaunaWhisperer_BG32_837_G],\r\n\tendOfTurn: (minion: BoardEntity, input: EndOfTurnInput) => {\r\n\t\tconst index = input.board.indexOf(minion);\r\n\t\tif (index === 0) {\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tconst targets: BoardEntity[] = [];\r\n\t\ttargets.push(input.board[index - 1]);\r\n\r\n\t\tif (minion.cardId === CardIds.FaunaWhisperer_BG32_837_G && index < input.board.length - 1) {\r\n\t\t\ttargets.push(input.board[index + 1]);\r\n\t\t}\r\n\r\n\t\tfor (const target of targets) {\r\n\t\t\tconst targetRaces = (input.gameState.allCards.getCard(target.cardId).races ?? []).map((r) => Race[r]);\r\n\t\t\tconst spellTargets = selectMinions(input.board, targetRaces, input.gameState.allCards);\r\n\t\t\tfor (const spellTarget of spellTargets) {\r\n\t\t\t\tmodifyStats(spellTarget, minion, 2, 2, input.board, input.hero, input.gameState);\r\n\t\t\t}\r\n\t\t}\r\n\t},\r\n};\r\n"]}