@firestone-hs/simulate-bgs-battle 1.1.600 → 1.1.602

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 (257) 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/board-entity.d.ts +10 -9
  4. package/dist/board-entity.js.map +1 -1
  5. package/dist/cards/card.interface.d.ts +7 -7
  6. package/dist/cards/card.interface.js +3 -3
  7. package/dist/cards/card.interface.js.map +1 -1
  8. package/dist/cards/cards-data.d.ts +1 -0
  9. package/dist/cards/cards-data.js +8 -10
  10. package/dist/cards/cards-data.js.map +1 -1
  11. package/dist/cards/impl/_card-mappings.js +112 -2
  12. package/dist/cards/impl/_card-mappings.js.map +1 -1
  13. package/dist/cards/impl/minion/all-seeing-elder.d.ts +2 -0
  14. package/dist/cards/impl/minion/all-seeing-elder.js +18 -0
  15. package/dist/cards/impl/minion/all-seeing-elder.js.map +1 -0
  16. package/dist/cards/impl/minion/avalanche-caller.d.ts +2 -0
  17. package/dist/cards/impl/minion/avalanche-caller.js +14 -0
  18. package/dist/cards/impl/minion/avalanche-caller.js.map +1 -0
  19. package/dist/cards/impl/minion/bigwig-bandit.d.ts +2 -0
  20. package/dist/cards/impl/minion/bigwig-bandit.js +14 -0
  21. package/dist/cards/impl/minion/bigwig-bandit.js.map +1 -0
  22. package/dist/cards/impl/minion/bile-spitter.d.ts +2 -0
  23. package/dist/cards/impl/minion/bile-spitter.js +28 -0
  24. package/dist/cards/impl/minion/bile-spitter.js.map +1 -0
  25. package/dist/cards/impl/minion/bloodsnout-warlord.d.ts +2 -0
  26. package/dist/cards/impl/minion/bloodsnout-warlord.js +18 -0
  27. package/dist/cards/impl/minion/bloodsnout-warlord.js.map +1 -0
  28. package/dist/cards/impl/minion/blue-whelp.d.ts +2 -0
  29. package/dist/cards/impl/minion/blue-whelp.js +15 -0
  30. package/dist/cards/impl/minion/blue-whelp.js.map +1 -0
  31. package/dist/cards/impl/minion/campfire-shadow.d.ts +2 -0
  32. package/dist/cards/impl/minion/campfire-shadow.js +20 -0
  33. package/dist/cards/impl/minion/campfire-shadow.js.map +1 -0
  34. package/dist/cards/impl/minion/canopy-swinger.d.ts +2 -0
  35. package/dist/cards/impl/minion/canopy-swinger.js +19 -0
  36. package/dist/cards/impl/minion/canopy-swinger.js.map +1 -0
  37. package/dist/cards/impl/minion/carapace-raiser.d.ts +2 -0
  38. package/dist/cards/impl/minion/carapace-raiser.js +14 -0
  39. package/dist/cards/impl/minion/carapace-raiser.js.map +1 -0
  40. package/dist/cards/impl/minion/charmwing.d.ts +2 -0
  41. package/dist/cards/impl/minion/charmwing.js +29 -0
  42. package/dist/cards/impl/minion/charmwing.js.map +1 -0
  43. package/dist/cards/impl/minion/coldlight-diver.d.ts +2 -0
  44. package/dist/cards/impl/minion/coldlight-diver.js +20 -0
  45. package/dist/cards/impl/minion/coldlight-diver.js.map +1 -0
  46. package/dist/cards/impl/minion/crystal-infuser-enchantment.js.map +1 -0
  47. package/dist/cards/impl/minion/cupcake-peddler.d.ts +2 -0
  48. package/dist/cards/impl/minion/cupcake-peddler.js +14 -0
  49. package/dist/cards/impl/minion/cupcake-peddler.js.map +1 -0
  50. package/dist/cards/impl/minion/deathly-striker.js +1 -1
  51. package/dist/cards/impl/minion/deathly-striker.js.map +1 -1
  52. package/dist/cards/impl/minion/devout-hellcaller.d.ts +2 -0
  53. package/dist/cards/impl/minion/devout-hellcaller.js +17 -0
  54. package/dist/cards/impl/minion/devout-hellcaller.js.map +1 -0
  55. package/dist/cards/impl/minion/drakkari-embalmer.d.ts +2 -0
  56. package/dist/cards/impl/minion/drakkari-embalmer.js +24 -0
  57. package/dist/cards/impl/minion/drakkari-embalmer.js.map +1 -0
  58. package/dist/cards/impl/minion/exceptionnal-caretaker.d.ts +2 -0
  59. package/dist/cards/impl/minion/exceptionnal-caretaker.js +37 -0
  60. package/dist/cards/impl/minion/exceptionnal-caretaker.js.map +1 -0
  61. package/dist/cards/impl/minion/fauna-whisperer.js +11 -8
  62. package/dist/cards/impl/minion/fauna-whisperer.js.map +1 -1
  63. package/dist/cards/impl/minion/fire-forged-evoker.js +1 -1
  64. package/dist/cards/impl/minion/fire-forged-evoker.js.map +1 -1
  65. package/dist/cards/impl/minion/flotsam-flinger.d.ts +2 -0
  66. package/dist/cards/impl/minion/flotsam-flinger.js +17 -0
  67. package/dist/cards/impl/minion/flotsam-flinger.js.map +1 -0
  68. package/dist/cards/impl/minion/friendly-geist.d.ts +2 -0
  69. package/dist/cards/impl/minion/friendly-geist.js +12 -0
  70. package/dist/cards/impl/minion/friendly-geist.js.map +1 -0
  71. package/dist/cards/impl/minion/geared-guard.d.ts +2 -0
  72. package/dist/cards/impl/minion/geared-guard.js +23 -0
  73. package/dist/cards/impl/minion/geared-guard.js.map +1 -0
  74. package/dist/cards/impl/minion/gleaming-trader.d.ts +2 -0
  75. package/dist/cards/impl/minion/gleaming-trader.js +13 -0
  76. package/dist/cards/impl/minion/gleaming-trader.js.map +1 -0
  77. package/dist/cards/impl/minion/goldgrubber.js +1 -1
  78. package/dist/cards/impl/minion/goldgrubber.js.map +1 -1
  79. package/dist/cards/impl/minion/greedy-snaketongue.d.ts +2 -0
  80. package/dist/cards/impl/minion/greedy-snaketongue.js +17 -0
  81. package/dist/cards/impl/minion/greedy-snaketongue.js.map +1 -0
  82. package/dist/cards/impl/minion/greenskeeper.d.ts +2 -2
  83. package/dist/cards/impl/minion/greenskeeper.js +3 -2
  84. package/dist/cards/impl/minion/greenskeeper.js.map +1 -1
  85. package/dist/cards/impl/minion/hoarding-hatespawn.js +1 -1
  86. package/dist/cards/impl/minion/hoarding-hatespawn.js.map +1 -1
  87. package/dist/cards/impl/minion/hog-watcher.d.ts +2 -0
  88. package/dist/cards/impl/minion/hog-watcher.js +20 -0
  89. package/dist/cards/impl/minion/hog-watcher.js.map +1 -0
  90. package/dist/cards/impl/minion/hot-springer.d.ts +2 -0
  91. package/dist/cards/impl/minion/hot-springer.js +19 -0
  92. package/dist/cards/impl/minion/hot-springer.js.map +1 -0
  93. package/dist/cards/impl/minion/lightfeather-screecher.d.ts +2 -0
  94. package/dist/cards/impl/minion/lightfeather-screecher.js +23 -0
  95. package/dist/cards/impl/minion/lightfeather-screecher.js.map +1 -0
  96. package/dist/cards/impl/minion/lokholar-frostforger.d.ts +1 -1
  97. package/dist/cards/impl/minion/lokholar-frostforger.js +3 -3
  98. package/dist/cards/impl/minion/lokholar-frostforger.js.map +1 -1
  99. package/dist/cards/impl/minion/lord-of-the-ruins.d.ts +2 -0
  100. package/dist/cards/impl/minion/lord-of-the-ruins.js +19 -0
  101. package/dist/cards/impl/minion/lord-of-the-ruins.js.map +1 -0
  102. package/dist/cards/impl/minion/lost-city-looter.d.ts +2 -0
  103. package/dist/cards/impl/minion/lost-city-looter.js +13 -0
  104. package/dist/cards/impl/minion/lost-city-looter.js.map +1 -0
  105. package/dist/cards/impl/minion/monstrous-macaw.d.ts +2 -2
  106. package/dist/cards/impl/minion/monstrous-macaw.js +3 -2
  107. package/dist/cards/impl/minion/monstrous-macaw.js.map +1 -1
  108. package/dist/cards/impl/minion/nimble-hatchling.d.ts +2 -0
  109. package/dist/cards/impl/minion/nimble-hatchling.js +14 -0
  110. package/dist/cards/impl/minion/nimble-hatchling.js.map +1 -0
  111. package/dist/cards/impl/minion/noisul-of-the-many-faces.js +1 -1
  112. package/dist/cards/impl/minion/noisul-of-the-many-faces.js.map +1 -1
  113. package/dist/cards/impl/minion/oranomonos-the-wilted.d.ts +2 -0
  114. package/dist/cards/impl/minion/oranomonos-the-wilted.js +11 -0
  115. package/dist/cards/impl/minion/oranomonos-the-wilted.js.map +1 -0
  116. package/dist/cards/impl/minion/poultron.d.ts +2 -0
  117. package/dist/cards/impl/minion/poultron.js +20 -0
  118. package/dist/cards/impl/minion/poultron.js.map +1 -0
  119. package/dist/cards/impl/minion/primeval-monstrosity.d.ts +2 -0
  120. package/dist/cards/impl/minion/primeval-monstrosity.js +16 -0
  121. package/dist/cards/impl/minion/primeval-monstrosity.js.map +1 -0
  122. package/dist/cards/impl/minion/prodigious-tusker.d.ts +2 -0
  123. package/dist/cards/impl/minion/prodigious-tusker.js +16 -0
  124. package/dist/cards/impl/minion/prodigious-tusker.js.map +1 -0
  125. package/dist/cards/impl/minion/raptor-elder.d.ts +2 -0
  126. package/dist/cards/impl/minion/raptor-elder.js +42 -0
  127. package/dist/cards/impl/minion/raptor-elder.js.map +1 -0
  128. package/dist/cards/impl/minion/razorfen-vineweaver.d.ts +2 -0
  129. package/dist/cards/impl/minion/razorfen-vineweaver.js +16 -0
  130. package/dist/cards/impl/minion/razorfen-vineweaver.js.map +1 -0
  131. package/dist/cards/impl/minion/red-whelp.js +1 -1
  132. package/dist/cards/impl/minion/red-whelp.js.map +1 -1
  133. package/dist/cards/impl/minion/ride-or-die.d.ts +2 -0
  134. package/dist/cards/impl/minion/ride-or-die.js +35 -0
  135. package/dist/cards/impl/minion/ride-or-die.js.map +1 -0
  136. package/dist/cards/impl/minion/roadboar.d.ts +2 -0
  137. package/dist/cards/impl/minion/roadboar.js +17 -0
  138. package/dist/cards/impl/minion/roadboar.js.map +1 -0
  139. package/dist/cards/impl/minion/ruins-renovator.d.ts +2 -0
  140. package/dist/cards/impl/minion/ruins-renovator.js +17 -0
  141. package/dist/cards/impl/minion/ruins-renovator.js.map +1 -0
  142. package/dist/cards/impl/minion/sanctum-rester.js +1 -1
  143. package/dist/cards/impl/minion/sanctum-rester.js.map +1 -1
  144. package/dist/cards/impl/minion/sanguine-refiner.d.ts +2 -0
  145. package/dist/cards/impl/minion/sanguine-refiner.js +16 -0
  146. package/dist/cards/impl/minion/sanguine-refiner.js.map +1 -0
  147. package/dist/cards/impl/minion/scourge-harvester.d.ts +2 -0
  148. package/dist/cards/impl/minion/scourge-harvester.js +16 -0
  149. package/dist/cards/impl/minion/scourge-harvester.js.map +1 -0
  150. package/dist/cards/impl/minion/sharp-eyed-sabretooth.d.ts +2 -0
  151. package/dist/cards/impl/minion/sharp-eyed-sabretooth.js +20 -0
  152. package/dist/cards/impl/minion/sharp-eyed-sabretooth.js.map +1 -0
  153. package/dist/cards/impl/minion/ship-master-eudora.d.ts +2 -0
  154. package/dist/cards/impl/minion/ship-master-eudora.js +13 -0
  155. package/dist/cards/impl/minion/ship-master-eudora.js.map +1 -0
  156. package/dist/cards/impl/minion/shipwrecked-rascal.d.ts +2 -0
  157. package/dist/cards/impl/minion/shipwrecked-rascal.js +20 -0
  158. package/dist/cards/impl/minion/shipwrecked-rascal.js.map +1 -0
  159. package/dist/cards/impl/minion/silent-enforcer.d.ts +2 -0
  160. package/dist/cards/impl/minion/silent-enforcer.js +23 -0
  161. package/dist/cards/impl/minion/silent-enforcer.js.map +1 -0
  162. package/dist/cards/impl/minion/sleepy-supporter.d.ts +2 -0
  163. package/dist/cards/impl/minion/sleepy-supporter.js +24 -0
  164. package/dist/cards/impl/minion/sleepy-supporter.js.map +1 -0
  165. package/dist/cards/impl/minion/stomping-stegodon-enchantment.d.ts +2 -0
  166. package/dist/cards/impl/minion/stomping-stegodon-enchantment.js +32 -0
  167. package/dist/cards/impl/minion/stomping-stegodon-enchantment.js.map +1 -0
  168. package/dist/cards/impl/minion/stomping-stegodon.d.ts +2 -0
  169. package/dist/cards/impl/minion/stomping-stegodon.js +29 -0
  170. package/dist/cards/impl/minion/stomping-stegodon.js.map +1 -0
  171. package/dist/cards/impl/minion/stray-satyr.d.ts +2 -0
  172. package/dist/cards/impl/minion/stray-satyr.js +16 -0
  173. package/dist/cards/impl/minion/stray-satyr.js.map +1 -0
  174. package/dist/cards/impl/minion/tusked-camper.d.ts +2 -0
  175. package/dist/cards/impl/minion/tusked-camper.js +16 -0
  176. package/dist/cards/impl/minion/tusked-camper.js.map +1 -0
  177. package/dist/cards/impl/minion/twilight-watcher.d.ts +2 -0
  178. package/dist/cards/impl/minion/twilight-watcher.js +21 -0
  179. package/dist/cards/impl/minion/twilight-watcher.js.map +1 -0
  180. package/dist/cards/impl/minion/vengeful-protector.d.ts +2 -0
  181. package/dist/cards/impl/minion/vengeful-protector.js +19 -0
  182. package/dist/cards/impl/minion/vengeful-protector.js.map +1 -0
  183. package/dist/cards/impl/minion/void-earl.d.ts +2 -0
  184. package/dist/cards/impl/minion/void-earl.js +12 -0
  185. package/dist/cards/impl/minion/void-earl.js.map +1 -0
  186. package/dist/cards/impl/minion/whirring-protector-enchantment.d.ts +2 -0
  187. package/dist/cards/impl/minion/whirring-protector-enchantment.js +19 -0
  188. package/dist/cards/impl/minion/whirring-protector-enchantment.js.map +1 -0
  189. package/dist/cards/impl/minion/whirring-protector.d.ts +2 -0
  190. package/dist/cards/impl/minion/whirring-protector.js +16 -0
  191. package/dist/cards/impl/minion/whirring-protector.js.map +1 -0
  192. package/dist/cards/impl/minion/wrathscale-rogue.d.ts +2 -0
  193. package/dist/cards/impl/minion/wrathscale-rogue.js +20 -0
  194. package/dist/cards/impl/minion/wrathscale-rogue.js.map +1 -0
  195. package/dist/cards/impl/minion/yorik-smite.d.ts +2 -0
  196. package/dist/cards/impl/minion/yorik-smite.js +16 -0
  197. package/dist/cards/impl/minion/yorik-smite.js.map +1 -0
  198. package/dist/cards/impl/minion/young-murk-eye.d.ts +2 -0
  199. package/dist/cards/impl/minion/young-murk-eye.js +22 -0
  200. package/dist/cards/impl/minion/young-murk-eye.js.map +1 -0
  201. package/dist/cards/impl/minion/yrel.d.ts +2 -0
  202. package/dist/cards/impl/minion/yrel.js +16 -0
  203. package/dist/cards/impl/minion/yrel.js.map +1 -0
  204. package/dist/cards/impl/quest-reward/stand-as-one.d.ts +2 -0
  205. package/dist/cards/impl/quest-reward/stand-as-one.js +18 -0
  206. package/dist/cards/impl/quest-reward/stand-as-one.js.map +1 -0
  207. package/dist/cards/impl/trinket/eternal-portrait.d.ts +1 -1
  208. package/dist/cards/impl/trinket/eternal-portrait.js +1 -1
  209. package/dist/cards/impl/trinket/eternal-portrait.js.map +1 -1
  210. package/dist/keywords/divine-shield.js +1 -16
  211. package/dist/keywords/divine-shield.js.map +1 -1
  212. package/dist/simulate-bgs-battle.js +0 -4
  213. package/dist/simulate-bgs-battle.js.map +1 -1
  214. package/dist/simulation/add-minion-to-board.js +11 -49
  215. package/dist/simulation/add-minion-to-board.js.map +1 -1
  216. package/dist/simulation/after-attack.js +1 -35
  217. package/dist/simulation/after-attack.js.map +1 -1
  218. package/dist/simulation/attack.js +14 -63
  219. package/dist/simulation/attack.js.map +1 -1
  220. package/dist/simulation/auras.js +25 -70
  221. package/dist/simulation/auras.js.map +1 -1
  222. package/dist/simulation/avenge.js +0 -50
  223. package/dist/simulation/avenge.js.map +1 -1
  224. package/dist/simulation/battlecries.js +11 -131
  225. package/dist/simulation/battlecries.js.map +1 -1
  226. package/dist/simulation/damage-effects.d.ts +9 -1
  227. package/dist/simulation/damage-effects.js +43 -83
  228. package/dist/simulation/damage-effects.js.map +1 -1
  229. package/dist/simulation/damage-to-hero.js +11 -0
  230. package/dist/simulation/damage-to-hero.js.map +1 -1
  231. package/dist/simulation/deathrattle-effects.js +7 -76
  232. package/dist/simulation/deathrattle-effects.js.map +1 -1
  233. package/dist/simulation/deathrattle-orchestration.js +2 -3
  234. package/dist/simulation/deathrattle-orchestration.js.map +1 -1
  235. package/dist/simulation/deathrattle-spawns.js +4 -65
  236. package/dist/simulation/deathrattle-spawns.js.map +1 -1
  237. package/dist/simulation/frenzy.js +0 -6
  238. package/dist/simulation/frenzy.js.map +1 -1
  239. package/dist/simulation/on-attack.d.ts +1 -0
  240. package/dist/simulation/on-attack.js +113 -92
  241. package/dist/simulation/on-attack.js.map +1 -1
  242. package/dist/simulation/on-being-attacked.js +1 -25
  243. package/dist/simulation/on-being-attacked.js.map +1 -1
  244. package/dist/simulation/reborn.js +1 -1
  245. package/dist/simulation/reborn.js.map +1 -1
  246. package/dist/simulation/remove-minion-from-board.js +0 -9
  247. package/dist/simulation/remove-minion-from-board.js.map +1 -1
  248. package/dist/simulation/simulator.js +3 -0
  249. package/dist/simulation/simulator.js.map +1 -1
  250. package/dist/simulation/start-of-combat/soc-action-processor.js +0 -12
  251. package/dist/simulation/start-of-combat/soc-action-processor.js.map +1 -1
  252. package/dist/utils.js +2 -11
  253. package/dist/utils.js.map +1 -1
  254. package/package.json +3 -3
  255. package/dist/cards/impl/enchantments/crystal-infuser-enchantment.js.map +0 -1
  256. /package/dist/cards/impl/{enchantments → minion}/crystal-infuser-enchantment.d.ts +0 -0
  257. /package/dist/cards/impl/{enchantments → minion}/crystal-infuser-enchantment.js +0 -0
@@ -1,2 +1,2 @@
1
- import { OnAfterAttackCard } from '../../card.interface';
2
- export declare const Greenskeeper: OnAfterAttackCard;
1
+ import { OnAttackCard } from '../../card.interface';
2
+ export declare const Greenskeeper: OnAttackCard;
@@ -4,15 +4,16 @@ exports.Greenskeeper = void 0;
4
4
  const battlecries_1 = require("../../../simulation/battlecries");
5
5
  exports.Greenskeeper = {
6
6
  cardIds: ["BG30_008", "BG30_008_G"],
7
- onAnyMinionAfterAttack: (minion, input) => {
7
+ onAnyMinionAttack: (minion, input) => {
8
8
  if (minion !== input.attacker) {
9
- return;
9
+ return { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };
10
10
  }
11
11
  const battlecries = input.attackingBoard.filter((e) => (0, battlecries_1.hasMinionBattlecry)(e, input.gameState));
12
12
  const candidate = battlecries[battlecries.length - 1];
13
13
  if (!!candidate) {
14
14
  (0, battlecries_1.triggerBattlecry)(input.attackingBoard, input.attackingHero, candidate, input.defendingBoard, input.defendingHero, input.gameState);
15
15
  }
16
+ return { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };
16
17
  },
17
18
  };
18
19
  //# sourceMappingURL=greenskeeper.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"greenskeeper.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/greenskeeper.ts"],"names":[],"mappings":";;;AAGA,iEAAuF;AAG1E,QAAA,YAAY,GAAsB;IAC9C,OAAO,EAAE,0BAAgE;IACzE,sBAAsB,EAAE,CAAC,MAAmB,EAAE,KAAyB,EAAE,EAAE;QAC1E,IAAI,MAAM,KAAK,KAAK,CAAC,QAAQ,EAAE;YAC9B,OAAO;SACP;QAED,MAAM,WAAW,GAAG,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,gCAAkB,EAAC,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;QAC/F,MAAM,SAAS,GAAG,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACtD,IAAI,CAAC,CAAC,SAAS,EAAE;YAChB,IAAA,8BAAgB,EACf,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,aAAa,EACnB,SAAS,EACT,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,SAAS,CACf,CAAC;SACF;IACF,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { OnAfterAttackInput } from '../../../simulation/after-attack';\r\nimport { hasMinionBattlecry, triggerBattlecry } from '../../../simulation/battlecries';\r\nimport { OnAfterAttackCard } from '../../card.interface';\r\n\r\nexport const Greenskeeper: OnAfterAttackCard = {\r\n\tcardIds: [CardIds.Greenskeeper_BG30_008, CardIds.Greenskeeper_BG30_008_G],\r\n\tonAnyMinionAfterAttack: (minion: BoardEntity, input: OnAfterAttackInput) => {\r\n\t\tif (minion !== input.attacker) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst battlecries = input.attackingBoard.filter((e) => hasMinionBattlecry(e, input.gameState));\r\n\t\tconst candidate = battlecries[battlecries.length - 1];\r\n\t\tif (!!candidate) {\r\n\t\t\ttriggerBattlecry(\r\n\t\t\t\tinput.attackingBoard,\r\n\t\t\t\tinput.attackingHero,\r\n\t\t\t\tcandidate,\r\n\t\t\t\tinput.defendingBoard,\r\n\t\t\t\tinput.defendingHero,\r\n\t\t\t\tinput.gameState,\r\n\t\t\t);\r\n\t\t}\r\n\t},\r\n};\r\n"]}
1
+ {"version":3,"file":"greenskeeper.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/greenskeeper.ts"],"names":[],"mappings":";;;AAEA,iEAAuF;AAI1E,QAAA,YAAY,GAAiB;IACzC,OAAO,EAAE,0BAAgE;IACzE,iBAAiB,EAAE,CAAC,MAAmB,EAAE,KAAoB,EAAE,EAAE;QAChE,IAAI,MAAM,KAAK,KAAK,CAAC,QAAQ,EAAE;YAC9B,OAAO,EAAE,iBAAiB,EAAE,CAAC,EAAE,iBAAiB,EAAE,CAAC,EAAE,CAAC;SACtD;QAED,MAAM,WAAW,GAAG,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,gCAAkB,EAAC,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;QAC/F,MAAM,SAAS,GAAG,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACtD,IAAI,CAAC,CAAC,SAAS,EAAE;YAChB,IAAA,8BAAgB,EACf,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,aAAa,EACnB,SAAS,EACT,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,SAAS,CACf,CAAC;SACF;QAED,OAAO,EAAE,iBAAiB,EAAE,CAAC,EAAE,iBAAiB,EAAE,CAAC,EAAE,CAAC;IACvD,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { hasMinionBattlecry, triggerBattlecry } from '../../../simulation/battlecries';\r\nimport { OnAttackInput } from '../../../simulation/on-attack';\r\nimport { OnAttackCard } from '../../card.interface';\r\n\r\nexport const Greenskeeper: OnAttackCard = {\r\n\tcardIds: [CardIds.Greenskeeper_BG30_008, CardIds.Greenskeeper_BG30_008_G],\r\n\tonAnyMinionAttack: (minion: BoardEntity, input: OnAttackInput) => {\r\n\t\tif (minion !== input.attacker) {\r\n\t\t\treturn { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };\r\n\t\t}\r\n\r\n\t\tconst battlecries = input.attackingBoard.filter((e) => hasMinionBattlecry(e, input.gameState));\r\n\t\tconst candidate = battlecries[battlecries.length - 1];\r\n\t\tif (!!candidate) {\r\n\t\t\ttriggerBattlecry(\r\n\t\t\t\tinput.attackingBoard,\r\n\t\t\t\tinput.attackingHero,\r\n\t\t\t\tcandidate,\r\n\t\t\t\tinput.defendingBoard,\r\n\t\t\t\tinput.defendingHero,\r\n\t\t\t\tinput.gameState,\r\n\t\t\t);\r\n\t\t}\r\n\r\n\t\treturn { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };\r\n\t},\r\n};\r\n"]}
@@ -5,7 +5,7 @@ const stats_1 = require("../../../simulation/stats");
5
5
  const utils_1 = require("../../../utils");
6
6
  exports.HoardingHatespawn = {
7
7
  startOfCombat: (minion, input) => {
8
- const stats = minion.cardId === "BG29_872_G" ? 20 : 10;
8
+ const stats = 10;
9
9
  const target = (0, utils_1.getRandomMinionWithHighestHealth)(input.opponentBoard);
10
10
  if (!!target) {
11
11
  const previousAttack = target.attack;
@@ -1 +1 @@
1
- {"version":3,"file":"hoarding-hatespawn.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/hoarding-hatespawn.ts"],"names":[],"mappings":";;;AAGA,qDAAwD;AACxD,0CAAkE;AAErD,QAAA,iBAAiB,GAAG;IAChC,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QACvD,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,iBAAyC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC/E,MAAM,MAAM,GAAG,IAAA,wCAAgC,EAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QACrE,IAAI,CAAC,CAAC,MAAM,EAAE;YACb,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC;YACrC,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC;YACrC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC;YACnD,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC;YACnD,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC;YACzD,IAAA,mBAAW,EACV,MAAM,EACN,MAAM,EACN,cAAc,GAAG,MAAM,CAAC,MAAM,EAC9B,cAAc,GAAG,MAAM,CAAC,MAAM,EAC9B,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,SAAS,EACf,KAAK,CACL,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 { getRandomMinionWithHighestHealth } from '../../../utils';\r\n\r\nexport const HoardingHatespawn = {\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst stats = minion.cardId === CardIds.HoardingHatespawn_BG29_872_G ? 20 : 10;\r\n\t\tconst target = getRandomMinionWithHighestHealth(input.opponentBoard);\r\n\t\tif (!!target) {\r\n\t\t\tconst previousAttack = target.attack;\r\n\t\t\tconst previousHealth = target.health;\r\n\t\t\ttarget.attack = Math.max(0, target.attack - stats);\r\n\t\t\ttarget.health = Math.max(0, target.health - stats);\r\n\t\t\ttarget.maxHealth = Math.max(0, target.maxHealth - stats);\r\n\t\t\tmodifyStats(\r\n\t\t\t\tminion,\r\n\t\t\t\tminion,\r\n\t\t\t\tpreviousAttack - target.attack,\r\n\t\t\t\tpreviousHealth - target.health,\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\tfalse,\r\n\t\t\t);\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}\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
1
+ {"version":3,"file":"hoarding-hatespawn.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/hoarding-hatespawn.ts"],"names":[],"mappings":";;;AAEA,qDAAwD;AACxD,0CAAkE;AAErD,QAAA,iBAAiB,GAAG;IAChC,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QACvD,MAAM,KAAK,GAAG,EAAE,CAAC;QACjB,MAAM,MAAM,GAAG,IAAA,wCAAgC,EAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QACrE,IAAI,CAAC,CAAC,MAAM,EAAE;YACb,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC;YACrC,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC;YACrC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC;YACnD,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC;YACnD,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC;YACzD,IAAA,mBAAW,EACV,MAAM,EACN,MAAM,EACN,cAAc,GAAG,MAAM,CAAC,MAAM,EAC9B,cAAc,GAAG,MAAM,CAAC,MAAM,EAC9B,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,SAAS,EACf,KAAK,CACL,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 { BoardEntity } from '../../../board-entity';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { getRandomMinionWithHighestHealth } from '../../../utils';\r\n\r\nexport const HoardingHatespawn = {\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst stats = 10; //minion.cardId === CardIds.HoardingHatespawn_BG29_872_G ? 20 : 10;\r\n\t\tconst target = getRandomMinionWithHighestHealth(input.opponentBoard);\r\n\t\tif (!!target) {\r\n\t\t\tconst previousAttack = target.attack;\r\n\t\t\tconst previousHealth = target.health;\r\n\t\t\ttarget.attack = Math.max(0, target.attack - stats);\r\n\t\t\ttarget.health = Math.max(0, target.health - stats);\r\n\t\t\ttarget.maxHealth = Math.max(0, target.maxHealth - stats);\r\n\t\t\tmodifyStats(\r\n\t\t\t\tminion,\r\n\t\t\t\tminion,\r\n\t\t\t\tpreviousAttack - target.attack,\r\n\t\t\t\tpreviousHealth - target.health,\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\tfalse,\r\n\t\t\t);\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}\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 HogWatcher: BattlecryCard;
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.HogWatcher = void 0;
4
+ const divine_shield_1 = require("../../../keywords/divine-shield");
5
+ const utils_1 = require("../../../services/utils");
6
+ exports.HogWatcher = {
7
+ cardIds: ["BG33_888", "BG33_888_G"],
8
+ battlecry: (minion, input) => {
9
+ const mult = minion.cardId === "BG33_888_G" ? 2 : 1;
10
+ for (let i = 0; i < mult; i++) {
11
+ const candidates = [...input.board, ...input.otherBoard].filter((e) => !e.divineShield);
12
+ const target = (0, utils_1.pickRandom)(candidates);
13
+ if (!!target) {
14
+ (0, divine_shield_1.updateDivineShield)(target, input.board, input.hero, input.otherHero, true, input.gameState);
15
+ }
16
+ }
17
+ return true;
18
+ },
19
+ };
20
+ //# sourceMappingURL=hog-watcher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hog-watcher.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/hog-watcher.ts"],"names":[],"mappings":";;;AAEA,mEAAqE;AACrE,mDAAqD;AAIxC,QAAA,UAAU,GAAkB;IACxC,OAAO,EAAE,0BAA4D;IACrE,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAW,EAAE;QAClE,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAAkC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACrE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC9B,MAAM,UAAU,GAAG,CAAC,GAAG,KAAK,CAAC,KAAK,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC;YACxF,MAAM,MAAM,GAAG,IAAA,kBAAU,EAAC,UAAU,CAAC,CAAC;YACtC,IAAI,CAAC,CAAC,MAAM,EAAE;gBACb,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;SACD;QACD,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { updateDivineShield } from '../../../keywords/divine-shield';\r\nimport { pickRandom } from '../../../services/utils';\r\nimport { BattlecryInput } from '../../../simulation/battlecries';\r\nimport { BattlecryCard } from '../../card.interface';\r\n\r\nexport const HogWatcher: BattlecryCard = {\r\n\tcardIds: [CardIds.HogWatcher_BG33_888, CardIds.HogWatcher_BG33_888_G],\r\n\tbattlecry: (minion: BoardEntity, input: BattlecryInput): boolean => {\r\n\t\tconst mult = minion.cardId === CardIds.HogWatcher_BG33_888_G ? 2 : 1;\r\n\t\tfor (let i = 0; i < mult; i++) {\r\n\t\t\tconst candidates = [...input.board, ...input.otherBoard].filter((e) => !e.divineShield);\r\n\t\t\tconst target = pickRandom(candidates);\r\n\t\t\tif (!!target) {\r\n\t\t\t\tupdateDivineShield(target, input.board, input.hero, input.otherHero, true, 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 { BattlecryCard } from '../../card.interface';
2
+ export declare const HotSpringer: BattlecryCard;
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.HotSpringer = 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.HotSpringer = {
8
+ cardIds: ["BG33_895", "BG33_895_G"],
9
+ battlecry: (minion, input) => {
10
+ const mult = minion.cardId === "BG33_895_G" ? 2 : 1;
11
+ const targets = input.board.filter((e) => e !== minion &&
12
+ (0, utils_1.hasCorrectTribe)(e, input.hero, reference_data_1.Race.MURLOC, input.gameState.anomalies, input.gameState.allCards));
13
+ for (const target of targets) {
14
+ (0, stats_1.modifyStats)(target, minion, 0, 3 * mult, input.board, input.hero, input.gameState);
15
+ }
16
+ return true;
17
+ },
18
+ };
19
+ //# sourceMappingURL=hot-springer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hot-springer.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/hot-springer.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAG7D,qDAAwD;AACxD,0CAAiD;AAGpC,QAAA,WAAW,GAAkB;IACzC,OAAO,EAAE,0BAA8D;IACvE,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAW,EAAE;QAClE,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAAmC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACtE,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CACjC,CAAC,CAAC,EAAE,EAAE,CACL,CAAC,KAAK,MAAM;YACZ,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,CACjG,CAAC;QACF,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;YAC7B,IAAA,mBAAW,EAAC,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;SACnF;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 { modifyStats } from '../../../simulation/stats';\r\nimport { hasCorrectTribe } from '../../../utils';\r\nimport { BattlecryCard } from '../../card.interface';\r\n\r\nexport const HotSpringer: BattlecryCard = {\r\n\tcardIds: [CardIds.HotSpringer_BG33_895, CardIds.HotSpringer_BG33_895_G],\r\n\tbattlecry: (minion: BoardEntity, input: BattlecryInput): boolean => {\r\n\t\tconst mult = minion.cardId === CardIds.HotSpringer_BG33_895_G ? 2 : 1;\r\n\t\tconst targets = input.board.filter(\r\n\t\t\t(e) =>\r\n\t\t\t\te !== minion &&\r\n\t\t\t\thasCorrectTribe(e, input.hero, Race.MURLOC, input.gameState.anomalies, input.gameState.allCards),\r\n\t\t);\r\n\t\tfor (const target of targets) {\r\n\t\t\tmodifyStats(target, minion, 0, 3 * mult, 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 { StartOfCombatCard } from '../../card.interface';
2
+ export declare const LightfeatherScreecher: StartOfCombatCard;
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LightfeatherScreecher = void 0;
4
+ const reference_data_1 = require("@firestone-hs/reference-data");
5
+ const taunt_1 = require("../../../keywords/taunt");
6
+ const windfury_1 = require("../../../keywords/windfury");
7
+ const utils_1 = require("../../../utils");
8
+ exports.LightfeatherScreecher = {
9
+ cardIds: ["BG33_841", "BG33_841_G"],
10
+ startOfCombat: (minion, input) => {
11
+ const mult = minion.cardId === "BG33_841_G" ? 2 : 1;
12
+ const candidates = input.playerBoard.filter((e) => (0, utils_1.hasCorrectTribe)(e, input.playerEntity, reference_data_1.Race.BEAST, input.gameState.anomalies, input.gameState.allCards));
13
+ for (let i = 0; i < mult; i++) {
14
+ const target = candidates[i];
15
+ if (!!target) {
16
+ (0, taunt_1.updateTaunt)(target, true, input.playerBoard, input.playerEntity, input.opponentEntity, input.gameState);
17
+ (0, windfury_1.updateWindfury)(target, true, input.playerBoard, input.playerEntity, input.opponentEntity, input.gameState);
18
+ }
19
+ }
20
+ return true;
21
+ },
22
+ };
23
+ //# sourceMappingURL=lightfeather-screecher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lightfeather-screecher.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/lightfeather-screecher.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAE7D,mDAAsD;AACtD,yDAA4D;AAE5D,0CAAiD;AAGpC,QAAA,qBAAqB,GAAsB;IACvD,OAAO,EAAE,0BAAkF;IAC3F,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QACvD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAA6C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAChF,MAAM,UAAU,GAAG,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CACjD,IAAA,uBAAe,EAAC,CAAC,EAAE,KAAK,CAAC,YAAY,EAAE,qBAAI,CAAC,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CACvG,CAAC;QACF,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC9B,MAAM,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;YAC7B,IAAI,CAAC,CAAC,MAAM,EAAE;gBACb,IAAA,mBAAW,EAAC,MAAM,EAAE,IAAI,EAAE,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,YAAY,EAAE,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;gBACxG,IAAA,yBAAc,EACb,MAAM,EACN,IAAI,EACJ,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,cAAc,EACpB,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 { updateTaunt } from '../../../keywords/taunt';\r\nimport { updateWindfury } from '../../../keywords/windfury';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { hasCorrectTribe } from '../../../utils';\r\nimport { StartOfCombatCard } from '../../card.interface';\r\n\r\nexport const LightfeatherScreecher: StartOfCombatCard = {\r\n\tcardIds: [CardIds.LightfeatherScreecher_BG33_841, CardIds.LightfeatherScreecher_BG33_841_G],\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.LightfeatherScreecher_BG33_841_G ? 2 : 1;\r\n\t\tconst candidates = input.playerBoard.filter((e) =>\r\n\t\t\thasCorrectTribe(e, input.playerEntity, Race.BEAST, input.gameState.anomalies, input.gameState.allCards),\r\n\t\t);\r\n\t\tfor (let i = 0; i < mult; i++) {\r\n\t\t\tconst target = candidates[i];\r\n\t\t\tif (!!target) {\r\n\t\t\t\tupdateTaunt(target, true, input.playerBoard, input.playerEntity, input.opponentEntity, input.gameState);\r\n\t\t\t\tupdateWindfury(\r\n\t\t\t\t\ttarget,\r\n\t\t\t\t\ttrue,\r\n\t\t\t\t\tinput.playerBoard,\r\n\t\t\t\t\tinput.playerEntity,\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,2 +1,2 @@
1
1
  import { EndOfTurnCard } from '../../card.interface';
2
- export declare const LokholarFrostforgeer: EndOfTurnCard;
2
+ export declare const LokholarFrostforger: EndOfTurnCard;
@@ -1,11 +1,11 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.LokholarFrostforgeer = void 0;
3
+ exports.LokholarFrostforger = void 0;
4
4
  const stats_1 = require("../../../simulation/stats");
5
- exports.LokholarFrostforgeer = {
5
+ exports.LokholarFrostforger = {
6
6
  cardIds: ["BG32_844", "BG32_844_G"],
7
7
  endOfTurn: (minion, input) => {
8
- const mult = minion.cardId === "BG32_844_G" ? 1 : 2;
8
+ const mult = minion.cardId === "BG32_844_G" ? 2 : 1;
9
9
  for (let i = 0; i < mult; i++) {
10
10
  const targets = input.board.filter((e) => e.entityId !== minion.entityId);
11
11
  for (const target of targets) {
@@ -1 +1 @@
1
- {"version":3,"file":"lokholar-frostforger.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/lokholar-frostforger.ts"],"names":[],"mappings":";;;AAEA,qDAAwD;AAG3C,QAAA,oBAAoB,GAAkB;IAClD,OAAO,EAAE,0BAA8E;IACvF,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAE,EAAE;QACzD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAA2C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9E,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC9B,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,IAAA,mBAAW,EAAC,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;aAC5E;SACD;IACF,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 LokholarFrostforgeer: EndOfTurnCard = {\r\n\tcardIds: [CardIds.LokholarFrostforger_BG32_844, CardIds.LokholarFrostforger_BG32_844_G],\r\n\tendOfTurn: (minion: BoardEntity, input: EndOfTurnInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.LokholarFrostforger_BG32_844_G ? 1 : 2;\r\n\t\tfor (let i = 0; i < mult; i++) {\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\tmodifyStats(target, minion, 3, 2, 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":"lokholar-frostforger.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/lokholar-frostforger.ts"],"names":[],"mappings":";;;AAEA,qDAAwD;AAG3C,QAAA,mBAAmB,GAAkB;IACjD,OAAO,EAAE,0BAA8E;IACvF,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAE,EAAE;QACzD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAA2C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9E,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC9B,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,IAAA,mBAAW,EAAC,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;aAC5E;SACD;IACF,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 LokholarFrostforger: EndOfTurnCard = {\r\n\tcardIds: [CardIds.LokholarFrostforger_BG32_844, CardIds.LokholarFrostforger_BG32_844_G],\r\n\tendOfTurn: (minion: BoardEntity, input: EndOfTurnInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.LokholarFrostforger_BG32_844_G ? 2 : 1;\r\n\t\tfor (let i = 0; i < mult; i++) {\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\tmodifyStats(target, minion, 3, 2, input.board, input.hero, input.gameState);\r\n\t\t\t}\r\n\t\t}\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { AfterDealDamageCard } from '../../card.interface';
2
+ export declare const LordOfTheRuins: AfterDealDamageCard;
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LordOfTheRuins = 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.LordOfTheRuins = {
8
+ cardIds: ["BG33_154", "BG33_154_G"],
9
+ afterDealDamage: (minion, input) => {
10
+ const mult = minion.cardId === "BG33_154_G" ? 2 : 1;
11
+ if ((0, utils_1.hasCorrectTribe)(input.damageDealer, input.hero, reference_data_1.Race.DEMON, input.gameState.anomalies, input.gameState.allCards)) {
12
+ const targets = input.board.filter((e) => e !== input.damageDealer);
13
+ for (const target of targets) {
14
+ (0, stats_1.modifyStats)(minion, target, 2 * mult, 2 * mult, input.board, input.hero, input.gameState);
15
+ }
16
+ }
17
+ },
18
+ };
19
+ //# sourceMappingURL=lord-of-the-ruins.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lord-of-the-ruins.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/lord-of-the-ruins.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAG7D,qDAAwD;AACxD,0CAAiD;AAGpC,QAAA,cAAc,GAAwB;IAClD,OAAO,EAAE,0BAAoE;IAC7E,eAAe,EAAE,CAAC,MAAmB,EAAE,KAA2B,EAAE,EAAE;QACrE,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAAsC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACzE,IACC,IAAA,uBAAe,EACd,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,IAAI,EACV,qBAAI,CAAC,KAAK,EACV,KAAK,CAAC,SAAS,CAAC,SAAS,EACzB,KAAK,CAAC,SAAS,CAAC,QAAQ,CACxB,EACA;YACD,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,KAAK,CAAC,YAAY,CAAC,CAAC;YACpE,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;gBAC7B,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 { AfterDealDamageInput } from '../../../simulation/damage-effects';\r\nimport { modifyStats } from '../../../simulation/stats';\r\nimport { hasCorrectTribe } from '../../../utils';\r\nimport { AfterDealDamageCard } from '../../card.interface';\r\n\r\nexport const LordOfTheRuins: AfterDealDamageCard = {\r\n\tcardIds: [CardIds.LordOfTheRuins_BG33_154, CardIds.LordOfTheRuins_BG33_154_G],\r\n\tafterDealDamage: (minion: BoardEntity, input: AfterDealDamageInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.LordOfTheRuins_BG33_154_G ? 2 : 1;\r\n\t\tif (\r\n\t\t\thasCorrectTribe(\r\n\t\t\t\tinput.damageDealer,\r\n\t\t\t\tinput.hero,\r\n\t\t\t\tRace.DEMON,\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 targets = input.board.filter((e) => e !== input.damageDealer);\r\n\t\t\tfor (const target of targets) {\r\n\t\t\t\tmodifyStats(minion, target, 2 * mult, 2 * mult, input.board, input.hero, input.gameState);\r\n\t\t\t}\r\n\t\t}\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { EndOfTurnCard } from '../../card.interface';
2
+ export declare const LostCityLooter: EndOfTurnCard;
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LostCityLooter = void 0;
4
+ const cards_in_hand_1 = require("../../../simulation/cards-in-hand");
5
+ exports.LostCityLooter = {
6
+ cardIds: ["BG33_820", "BG33_820_G"],
7
+ endOfTurn: (minion, input) => {
8
+ const mult = minion.cardId === "BG33_820_G" ? 2 : 1;
9
+ const cardsToAdd = Array(mult).fill(null);
10
+ (0, cards_in_hand_1.addCardsInHand)(input.hero, input.board, cardsToAdd, input.gameState);
11
+ },
12
+ };
13
+ //# sourceMappingURL=lost-city-looter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lost-city-looter.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/lost-city-looter.ts"],"names":[],"mappings":";;;AAEA,qEAAmE;AAGtD,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,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1C,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 { addCardsInHand } from '../../../simulation/cards-in-hand';\r\nimport { EndOfTurnCard, EndOfTurnInput } from '../../card.interface';\r\n\r\nexport const LostCityLooter: EndOfTurnCard = {\r\n\tcardIds: [CardIds.LostCityLooter_BG33_820, CardIds.LostCityLooter_BG33_820_G],\r\n\tendOfTurn: (minion: BoardEntity, input: EndOfTurnInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.LostCityLooter_BG33_820_G ? 2 : 1;\r\n\t\tconst cardsToAdd = Array(mult).fill(null);\r\n\t\taddCardsInHand(input.hero, input.board, cardsToAdd, input.gameState);\r\n\t},\r\n};\r\n"]}
@@ -1,2 +1,2 @@
1
- import { OnAfterAttackCard } from '../../card.interface';
2
- export declare const MonstrousMacaw: OnAfterAttackCard;
1
+ import { OnAttackCard } from '../../card.interface';
2
+ export declare const MonstrousMacaw: OnAttackCard;
@@ -6,10 +6,10 @@ const deathrattle_orchestration_1 = require("../../../simulation/deathrattle-orc
6
6
  const deathrattle_utils_1 = require("../../../simulation/deathrattle-utils");
7
7
  exports.MonstrousMacaw = {
8
8
  cardIds: ["BGS_078", "TB_BaconUps_135"],
9
- onAnyMinionAfterAttack: (minion, input) => {
9
+ onAnyMinionAttack: (minion, input) => {
10
10
  var _a;
11
11
  if (input.attacker !== minion) {
12
- return;
12
+ return { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };
13
13
  }
14
14
  const loops = minion.cardId === "TB_BaconUps_135" ? 2 : 1;
15
15
  const targetBoard = input.attackingBoard.filter((e) => e.entityId !== minion.entityId);
@@ -34,6 +34,7 @@ exports.MonstrousMacaw = {
34
34
  }
35
35
  }
36
36
  }
37
+ return { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };
37
38
  },
38
39
  };
39
40
  //# sourceMappingURL=monstrous-macaw.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"monstrous-macaw.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/monstrous-macaw.ts"],"names":[],"mappings":";;;AAGA,iEAAuF;AACvF,6FAA4F;AAC5F,6EAA6E;AAGhE,QAAA,cAAc,GAAsB;IAChD,OAAO,EAAE,8BAAwE;IACjF,sBAAsB,EAAE,CAAC,MAAmB,EAAE,KAAyB,EAAE,EAAE;;QAC1E,IAAI,KAAK,CAAC,QAAQ,KAAK,MAAM,EAAE;YAC9B,OAAO;SACP;QAED,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,sBAA2C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/E,MAAM,WAAW,GAAG,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC;QAEvF,MAAM,iBAAiB,GAAG,IAAA,wCAAoB,EAAC,WAAW,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QAClG,MAAM,mBAAmB,GAAG,iBAAiB,CAAC,CAAC,CAAC,CAAC;QACjD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE;YAC/B,IAAI,CAAC,CAAC,mBAAmB,EAAE;gBAC1B,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,mBAAmB,CAC5C,MAAM,EACN,mBAAmB,EACnB,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,aAAa,CACnB,CAAC;gBACF,MAAM,cAAc,GACnB,KAAK,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,CAAC;gBACvF,IAAA,uDAA2B,EAC1B,mBAAmB,EACnB,cAAc,EACd,CAAC,mBAAmB,CAAC,EACrB,mBAAmB,CAAC,QAAQ;oBAC3B,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM;oBAClC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,QAAQ,EACrC,mBAAmB,CAAC,QAAQ;oBAC3B,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,QAAQ;oBACpC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,EACnC,KAAK,CAAC,SAAS,EACf,KAAK,CACL,CAAC;aACF;YAED,IAAI,MAAA,KAAK,CAAC,aAAa,CAAC,QAAQ,0CAAE,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,yBAA6C,CAAC,EAAE;gBACrG,MAAM,gBAAgB,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,gCAAkB,EAAC,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;gBAC3F,MAAM,iBAAiB,GAAG,gBAAgB,CAAC,CAAC,CAAC,CAAC;gBAC9C,IAAI,CAAC,CAAC,iBAAiB,EAAE;oBACxB,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,mBAAmB,CAC5C,MAAM,EACN,iBAAiB,EACjB,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,aAAa,CACnB,CAAC;oBACF,IAAA,8BAAgB,EACf,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,aAAa,EACnB,iBAAiB,EACjB,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,SAAS,CACf,CAAC;iBACF;aACD;SACD;IACF,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { OnAfterAttackInput } from '../../../simulation/after-attack';\r\nimport { hasMinionBattlecry, triggerBattlecry } from '../../../simulation/battlecries';\r\nimport { processDeathrattleForMinion } from '../../../simulation/deathrattle-orchestration';\r\nimport { getValidDeathrattles } from '../../../simulation/deathrattle-utils';\r\nimport { OnAfterAttackCard } from '../../card.interface';\r\n\r\nexport const MonstrousMacaw: OnAfterAttackCard = {\r\n\tcardIds: [CardIds.MonstrousMacaw_BGS_078, CardIds.MonstrousMacaw_TB_BaconUps_135],\r\n\tonAnyMinionAfterAttack: (minion: BoardEntity, input: OnAfterAttackInput) => {\r\n\t\tif (input.attacker !== minion) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst loops = minion.cardId === CardIds.MonstrousMacaw_TB_BaconUps_135 ? 2 : 1;\r\n\t\tconst targetBoard = input.attackingBoard.filter((e) => e.entityId !== minion.entityId);\r\n\r\n\t\tconst validDeathrattles = getValidDeathrattles(targetBoard, input.attackingHero, input.gameState);\r\n\t\tconst leftMostDeathrattle = validDeathrattles[0];\r\n\t\tfor (let i = 0; i < loops; i++) {\r\n\t\t\tif (!!leftMostDeathrattle) {\r\n\t\t\t\tinput.gameState.spectator.registerPowerTarget(\r\n\t\t\t\t\tminion,\r\n\t\t\t\t\tleftMostDeathrattle,\r\n\t\t\t\t\tinput.attackingBoard,\r\n\t\t\t\t\tinput.attackingHero,\r\n\t\t\t\t\tinput.defendingHero,\r\n\t\t\t\t);\r\n\t\t\t\tconst indexFromRight =\r\n\t\t\t\t\tinput.attackingBoard.length - (input.attackingBoard.indexOf(leftMostDeathrattle) + 1);\r\n\t\t\t\tprocessDeathrattleForMinion(\r\n\t\t\t\t\tleftMostDeathrattle,\r\n\t\t\t\t\tindexFromRight,\r\n\t\t\t\t\t[leftMostDeathrattle],\r\n\t\t\t\t\tleftMostDeathrattle.friendly\r\n\t\t\t\t\t\t? input.gameState.gameState.player\r\n\t\t\t\t\t\t: input.gameState.gameState.opponent,\r\n\t\t\t\t\tleftMostDeathrattle.friendly\r\n\t\t\t\t\t\t? input.gameState.gameState.opponent\r\n\t\t\t\t\t\t: input.gameState.gameState.player,\r\n\t\t\t\t\tinput.gameState,\r\n\t\t\t\t\tfalse,\r\n\t\t\t\t);\r\n\t\t\t}\r\n\r\n\t\t\tif (input.attackingHero.trinkets?.some((t) => t.cardId === CardIds.MacawPortrait_BG32_MagicItem_803)) {\r\n\t\t\t\tconst validBattlecries = targetBoard.filter((e) => hasMinionBattlecry(e, input.gameState));\r\n\t\t\t\tconst leftMostBattlecry = validBattlecries[0];\r\n\t\t\t\tif (!!leftMostBattlecry) {\r\n\t\t\t\t\tinput.gameState.spectator.registerPowerTarget(\r\n\t\t\t\t\t\tminion,\r\n\t\t\t\t\t\tleftMostBattlecry,\r\n\t\t\t\t\t\tinput.attackingBoard,\r\n\t\t\t\t\t\tinput.attackingHero,\r\n\t\t\t\t\t\tinput.defendingHero,\r\n\t\t\t\t\t);\r\n\t\t\t\t\ttriggerBattlecry(\r\n\t\t\t\t\t\tinput.attackingBoard,\r\n\t\t\t\t\t\tinput.attackingHero,\r\n\t\t\t\t\t\tleftMostBattlecry,\r\n\t\t\t\t\t\tinput.defendingBoard,\r\n\t\t\t\t\t\tinput.defendingHero,\r\n\t\t\t\t\t\tinput.gameState,\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"]}
1
+ {"version":3,"file":"monstrous-macaw.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/monstrous-macaw.ts"],"names":[],"mappings":"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","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { hasMinionBattlecry, triggerBattlecry } from '../../../simulation/battlecries';\r\nimport { processDeathrattleForMinion } from '../../../simulation/deathrattle-orchestration';\r\nimport { getValidDeathrattles } from '../../../simulation/deathrattle-utils';\r\nimport { OnAttackInput } from '../../../simulation/on-attack';\r\nimport { OnAttackCard } from '../../card.interface';\r\n\r\nexport const MonstrousMacaw: OnAttackCard = {\r\n\tcardIds: [CardIds.MonstrousMacaw_BGS_078, CardIds.MonstrousMacaw_TB_BaconUps_135],\r\n\tonAnyMinionAttack: (minion: BoardEntity, input: OnAttackInput) => {\r\n\t\tif (input.attacker !== minion) {\r\n\t\t\treturn { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };\r\n\t\t}\r\n\r\n\t\tconst loops = minion.cardId === CardIds.MonstrousMacaw_TB_BaconUps_135 ? 2 : 1;\r\n\t\tconst targetBoard = input.attackingBoard.filter((e) => e.entityId !== minion.entityId);\r\n\r\n\t\tconst validDeathrattles = getValidDeathrattles(targetBoard, input.attackingHero, input.gameState);\r\n\t\tconst leftMostDeathrattle = validDeathrattles[0];\r\n\t\tfor (let i = 0; i < loops; i++) {\r\n\t\t\tif (!!leftMostDeathrattle) {\r\n\t\t\t\tinput.gameState.spectator.registerPowerTarget(\r\n\t\t\t\t\tminion,\r\n\t\t\t\t\tleftMostDeathrattle,\r\n\t\t\t\t\tinput.attackingBoard,\r\n\t\t\t\t\tinput.attackingHero,\r\n\t\t\t\t\tinput.defendingHero,\r\n\t\t\t\t);\r\n\t\t\t\tconst indexFromRight =\r\n\t\t\t\t\tinput.attackingBoard.length - (input.attackingBoard.indexOf(leftMostDeathrattle) + 1);\r\n\t\t\t\tprocessDeathrattleForMinion(\r\n\t\t\t\t\tleftMostDeathrattle,\r\n\t\t\t\t\tindexFromRight,\r\n\t\t\t\t\t[leftMostDeathrattle],\r\n\t\t\t\t\tleftMostDeathrattle.friendly\r\n\t\t\t\t\t\t? input.gameState.gameState.player\r\n\t\t\t\t\t\t: input.gameState.gameState.opponent,\r\n\t\t\t\t\tleftMostDeathrattle.friendly\r\n\t\t\t\t\t\t? input.gameState.gameState.opponent\r\n\t\t\t\t\t\t: input.gameState.gameState.player,\r\n\t\t\t\t\tinput.gameState,\r\n\t\t\t\t\tfalse,\r\n\t\t\t\t);\r\n\t\t\t}\r\n\r\n\t\t\tif (input.attackingHero.trinkets?.some((t) => t.cardId === CardIds.MacawPortrait_BG32_MagicItem_803)) {\r\n\t\t\t\tconst validBattlecries = targetBoard.filter((e) => hasMinionBattlecry(e, input.gameState));\r\n\t\t\t\tconst leftMostBattlecry = validBattlecries[0];\r\n\t\t\t\tif (!!leftMostBattlecry) {\r\n\t\t\t\t\tinput.gameState.spectator.registerPowerTarget(\r\n\t\t\t\t\t\tminion,\r\n\t\t\t\t\t\tleftMostBattlecry,\r\n\t\t\t\t\t\tinput.attackingBoard,\r\n\t\t\t\t\t\tinput.attackingHero,\r\n\t\t\t\t\t\tinput.defendingHero,\r\n\t\t\t\t\t);\r\n\t\t\t\t\ttriggerBattlecry(\r\n\t\t\t\t\t\tinput.attackingBoard,\r\n\t\t\t\t\t\tinput.attackingHero,\r\n\t\t\t\t\t\tleftMostBattlecry,\r\n\t\t\t\t\t\tinput.defendingBoard,\r\n\t\t\t\t\t\tinput.defendingHero,\r\n\t\t\t\t\t\tinput.gameState,\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 { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { BattlecryCard } from '../../card.interface';
2
+ export declare const NimbleHatchling: BattlecryCard;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NimbleHatchling = void 0;
4
+ const cards_in_hand_1 = require("../../../simulation/cards-in-hand");
5
+ exports.NimbleHatchling = {
6
+ cardIds: ["BG33_244", "BG33_244_G"],
7
+ battlecry: (minion, input) => {
8
+ const mult = minion.cardId === "BG33_244_G" ? 2 : 1;
9
+ const cardsToAdd = Array(mult).fill("BG33_248");
10
+ (0, cards_in_hand_1.addCardsInHand)(input.hero, input.board, cardsToAdd, input.gameState);
11
+ return true;
12
+ },
13
+ };
14
+ //# sourceMappingURL=nimble-hatchling.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nimble-hatchling.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/nimble-hatchling.ts"],"names":[],"mappings":";;;AAGA,qEAAmE;AAGtD,QAAA,eAAe,GAAkB;IAC7C,OAAO,EAAE,0BAAsE;IAC/E,SAAS,EAAE,CAAC,MAAmB,EAAE,KAAqB,EAAE,EAAE;QACzD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAAuC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1E,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,YAAiC,CAAC;QACrE,IAAA,8BAAc,EAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,EAAE,UAAU,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QACrE,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { BattlecryInput } from '../../../simulation/battlecries';\r\nimport { addCardsInHand } from '../../../simulation/cards-in-hand';\r\nimport { BattlecryCard } from '../../card.interface';\r\n\r\nexport const NimbleHatchling: BattlecryCard = {\r\n\tcardIds: [CardIds.NimbleHatchling_BG33_244, CardIds.NimbleHatchling_BG33_244_G],\r\n\tbattlecry: (minion: BoardEntity, input: BattlecryInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.NimbleHatchling_BG33_244_G ? 2 : 1;\r\n\t\tconst cardsToAdd = Array(mult).fill(CardIds.NimbleWingbeat_BG33_248);\r\n\t\taddCardsInHand(input.hero, input.board, cardsToAdd, input.gameState);\r\n\t\treturn true;\r\n\t},\r\n};\r\n"]}
@@ -13,7 +13,7 @@ exports.NoisulOfTheManyFaces = {
13
13
  const targets = input.board.filter((e) => (0, utils_1.hasCorrectTribe)(e, input.hero, reference_data_1.Race.UNDEAD, input.gameState.anomalies, input.gameState.allCards));
14
14
  const mult = minion.cardId === "BG32_325_G" ? 2 : 1;
15
15
  for (const target of targets) {
16
- (0, stats_1.modifyStats)(target, minion, 2 * mult, 1 * mult, input.board, input.hero, input.gameState);
16
+ (0, stats_1.modifyStats)(target, minion, 1 * mult, 1 * mult, input.board, input.hero, input.gameState);
17
17
  }
18
18
  },
19
19
  };
@@ -1 +1 @@
1
- {"version":3,"file":"noisul-of-the-many-faces.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/noisul-of-the-many-faces.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAG7D,qDAAwD;AACxD,0CAAiD;AAGpC,QAAA,oBAAoB,GAAuB;IACvD,OAAO,EAAE,0BAAgF;IACzF,cAAc,EAAE,CAAC,MAAmB,EAAE,KAAwB,EAAE,EAAE;QACjE,IACC,CAAC,IAAA,uBAAe,EACf,KAAK,CAAC,OAAO,EACb,KAAK,CAAC,IAAI,EACV,qBAAI,CAAC,MAAM,EACX,KAAK,CAAC,SAAS,CAAC,SAAS,EACzB,KAAK,CAAC,SAAS,CAAC,QAAQ,CACxB,EACA;YACD,OAAO;SACP;QACD,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CACxC,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,CAAC;QACF,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAA4C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/E,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;YAC7B,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;SAC1F;IACF,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, Race } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\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 NoisulOfTheManyFaces: OnOtherSpawnedCard = {\r\n\tcardIds: [CardIds.NoisulOfTheManyFaces_BG32_325, CardIds.NoisulOfTheManyFaces_BG32_325_G],\r\n\tonOtherSpawned: (minion: BoardEntity, input: OnOtherSpawnInput) => {\r\n\t\tif (\r\n\t\t\t!hasCorrectTribe(\r\n\t\t\t\tinput.spawned,\r\n\t\t\t\tinput.hero,\r\n\t\t\t\tRace.UNDEAD,\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\treturn;\r\n\t\t}\r\n\t\tconst targets = input.board.filter((e) =>\r\n\t\t\thasCorrectTribe(e, input.hero, Race.UNDEAD, input.gameState.anomalies, input.gameState.allCards),\r\n\t\t);\r\n\t\tconst mult = minion.cardId === CardIds.NoisulOfTheManyFaces_BG32_325_G ? 2 : 1;\r\n\t\tfor (const target of targets) {\r\n\t\t\tmodifyStats(target, minion, 2 * mult, 1 * mult, input.board, input.hero, input.gameState);\r\n\t\t}\r\n\t},\r\n};\r\n"]}
1
+ {"version":3,"file":"noisul-of-the-many-faces.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/noisul-of-the-many-faces.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAG7D,qDAAwD;AACxD,0CAAiD;AAGpC,QAAA,oBAAoB,GAAuB;IACvD,OAAO,EAAE,0BAAgF;IACzF,cAAc,EAAE,CAAC,MAAmB,EAAE,KAAwB,EAAE,EAAE;QACjE,IACC,CAAC,IAAA,uBAAe,EACf,KAAK,CAAC,OAAO,EACb,KAAK,CAAC,IAAI,EACV,qBAAI,CAAC,MAAM,EACX,KAAK,CAAC,SAAS,CAAC,SAAS,EACzB,KAAK,CAAC,SAAS,CAAC,QAAQ,CACxB,EACA;YACD,OAAO;SACP;QACD,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CACxC,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,CAAC;QACF,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAA4C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/E,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;YAC7B,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;SAC1F;IACF,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, Race } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\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 NoisulOfTheManyFaces: OnOtherSpawnedCard = {\r\n\tcardIds: [CardIds.NoisulOfTheManyFaces_BG32_325, CardIds.NoisulOfTheManyFaces_BG32_325_G],\r\n\tonOtherSpawned: (minion: BoardEntity, input: OnOtherSpawnInput) => {\r\n\t\tif (\r\n\t\t\t!hasCorrectTribe(\r\n\t\t\t\tinput.spawned,\r\n\t\t\t\tinput.hero,\r\n\t\t\t\tRace.UNDEAD,\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\treturn;\r\n\t\t}\r\n\t\tconst targets = input.board.filter((e) =>\r\n\t\t\thasCorrectTribe(e, input.hero, Race.UNDEAD, input.gameState.anomalies, input.gameState.allCards),\r\n\t\t);\r\n\t\tconst mult = minion.cardId === CardIds.NoisulOfTheManyFaces_BG32_325_G ? 2 : 1;\r\n\t\tfor (const target of targets) {\r\n\t\t\tmodifyStats(target, minion, 1 * mult, 1 * mult, input.board, input.hero, input.gameState);\r\n\t\t}\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { RebornEffectCard } from '../../card.interface';
2
+ export declare const OranomonosTheWilted: RebornEffectCard;
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.OranomonosTheWilted = void 0;
4
+ exports.OranomonosTheWilted = {
5
+ cardIds: ["BG33_116", "BG33_116_G"],
6
+ rebornEffect: (minion, input) => {
7
+ const mult = minion.cardId === "BG33_116_G" ? 2 : 1;
8
+ input.opponentBoardHero.globalInfo.UndeadAttackBonus += 1 * mult;
9
+ },
10
+ };
11
+ //# sourceMappingURL=oranomonos-the-wilted.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"oranomonos-the-wilted.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/oranomonos-the-wilted.ts"],"names":[],"mappings":";;;AAKa,QAAA,mBAAmB,GAAqB;IACpD,OAAO,EAAE,0BAA8E;IACvF,YAAY,EAAE,CAAC,MAAmB,EAAE,KAAwB,EAAQ,EAAE;QACrE,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAA2C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9E,KAAK,CAAC,iBAAiB,CAAC,UAAU,CAAC,iBAAiB,IAAI,CAAC,GAAG,IAAI,CAAC;IAClE,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { RebornEffectInput } from '../../../simulation/reborn';\r\nimport { RebornEffectCard } from '../../card.interface';\r\n\r\nexport const OranomonosTheWilted: RebornEffectCard = {\r\n\tcardIds: [CardIds.OranomonosTheWilted_BG33_116, CardIds.OranomonosTheWilted_BG33_116_G],\r\n\trebornEffect: (minion: BoardEntity, input: RebornEffectInput): void => {\r\n\t\tconst mult = minion.cardId === CardIds.OranomonosTheWilted_BG33_116_G ? 2 : 1;\r\n\t\tinput.opponentBoardHero.globalInfo.UndeadAttackBonus += 1 * mult;\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { AvengeCard } from '../../card.interface';
2
+ export declare const Poultron: AvengeCard;
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Poultron = void 0;
4
+ const divine_shield_1 = require("../../../keywords/divine-shield");
5
+ const attack_1 = require("../../../simulation/attack");
6
+ exports.Poultron = {
7
+ cardIds: ["BG33_371", "BG33_371_G"],
8
+ baseAvengeValue: (cardId) => 4,
9
+ avenge: (minion, input) => {
10
+ const mult = minion.cardId === "BG33_371_G" ? 2 : 1;
11
+ for (let i = 0; i < mult; i++) {
12
+ (0, divine_shield_1.updateDivineShield)(minion, input.board, input.hero, input.otherHero, true, input.gameState);
13
+ minion.attackImmediately = true;
14
+ (0, attack_1.simulateAttack)(input.board, input.hero, input.otherBoard, input.otherHero, input.gameState);
15
+ minion.hasAttacked = 0;
16
+ minion.attackImmediately = false;
17
+ }
18
+ },
19
+ };
20
+ //# sourceMappingURL=poultron.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"poultron.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/poultron.ts"],"names":[],"mappings":";;;AAEA,mEAAqE;AACrE,uDAA4D;AAI/C,QAAA,QAAQ,GAAe;IACnC,OAAO,EAAE,0BAAwD;IACjE,eAAe,EAAE,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;IAC9B,MAAM,EAAE,CAAC,MAAmB,EAAE,KAAkB,EAAE,EAAE;QACnD,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAAgC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACnE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC9B,IAAA,kCAAkB,EAAC,MAAM,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,EAAE,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;YAC5F,MAAM,CAAC,iBAAiB,GAAG,IAAI,CAAC;YAChC,IAAA,uBAAc,EAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;YAC5F,MAAM,CAAC,WAAW,GAAG,CAAC,CAAC;YACvB,MAAM,CAAC,iBAAiB,GAAG,KAAK,CAAC;SACjC;IACF,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { updateDivineShield } from '../../../keywords/divine-shield';\r\nimport { simulateAttack } from '../../../simulation/attack';\r\nimport { AvengeInput } from '../../../simulation/avenge';\r\nimport { AvengeCard } from '../../card.interface';\r\n\r\nexport const Poultron: AvengeCard = {\r\n\tcardIds: [CardIds.P0ulTr0n_BG33_371, CardIds.P0ulTr0n_BG33_371_G],\r\n\tbaseAvengeValue: (cardId) => 4,\r\n\tavenge: (minion: BoardEntity, input: AvengeInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.P0ulTr0n_BG33_371_G ? 2 : 1;\r\n\t\tfor (let i = 0; i < mult; i++) {\r\n\t\t\tupdateDivineShield(minion, input.board, input.hero, input.otherHero, true, input.gameState);\r\n\t\t\tminion.attackImmediately = true;\r\n\t\t\tsimulateAttack(input.board, input.hero, input.otherBoard, input.otherHero, input.gameState);\r\n\t\t\tminion.hasAttacked = 0;\r\n\t\t\tminion.attackImmediately = false;\r\n\t\t}\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { OnAttackCard } from '../../card.interface';
2
+ export declare const PrimevalMonstrosity: OnAttackCard;
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PrimevalMonstrosity = void 0;
4
+ const reference_data_1 = require("@firestone-hs/reference-data");
5
+ const utils_1 = require("../../../utils");
6
+ exports.PrimevalMonstrosity = {
7
+ cardIds: ["BG33_320", "BG33_320_G"],
8
+ onAnyMinionAttack: (minion, input) => {
9
+ if ((0, reference_data_1.hasMechanic)(input.gameState.allCards.getCard(input.attacker.cardId), reference_data_1.GameTag.BACON_RALLY)) {
10
+ const mult = minion.cardId === "BG33_320_G" ? 2 : 1;
11
+ (0, utils_1.grantStatsToMinionsOfEachType)(minion, input.attackingBoard, input.attackingHero, 3 * mult, 3 * mult, input.gameState);
12
+ }
13
+ return { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };
14
+ },
15
+ };
16
+ //# sourceMappingURL=primeval-monstrosity.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"primeval-monstrosity.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/primeval-monstrosity.ts"],"names":[],"mappings":";;;AAAA,iEAA6E;AAG7E,0CAA+D;AAGlD,QAAA,mBAAmB,GAAiB;IAChD,OAAO,EAAE,0BAA8E;IACvF,iBAAiB,EAAE,CAAC,MAAmB,EAAE,KAAoB,EAAE,EAAE;QAChE,IAAI,IAAA,4BAAW,EAAC,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,wBAAO,CAAC,WAAW,CAAC,EAAE;YAC9F,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAA2C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC9E,IAAA,qCAA6B,EAC5B,MAAM,EACN,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,aAAa,EACnB,CAAC,GAAG,IAAI,EACR,CAAC,GAAG,IAAI,EACR,KAAK,CAAC,SAAS,CACf,CAAC;SACF;QACD,OAAO,EAAE,iBAAiB,EAAE,CAAC,EAAE,iBAAiB,EAAE,CAAC,EAAE,CAAC;IACvD,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, GameTag, hasMechanic } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { OnAttackInput } from '../../../simulation/on-attack';\r\nimport { grantStatsToMinionsOfEachType } from '../../../utils';\r\nimport { OnAttackCard } from '../../card.interface';\r\n\r\nexport const PrimevalMonstrosity: OnAttackCard = {\r\n\tcardIds: [CardIds.PrimevalMonstrosity_BG33_320, CardIds.PrimevalMonstrosity_BG33_320_G],\r\n\tonAnyMinionAttack: (minion: BoardEntity, input: OnAttackInput) => {\r\n\t\tif (hasMechanic(input.gameState.allCards.getCard(input.attacker.cardId), GameTag.BACON_RALLY)) {\r\n\t\t\tconst mult = minion.cardId === CardIds.PrimevalMonstrosity_BG33_320_G ? 2 : 1;\r\n\t\t\tgrantStatsToMinionsOfEachType(\r\n\t\t\t\tminion,\r\n\t\t\t\tinput.attackingBoard,\r\n\t\t\t\tinput.attackingHero,\r\n\t\t\t\t3 * mult,\r\n\t\t\t\t3 * mult,\r\n\t\t\t\tinput.gameState,\r\n\t\t\t);\r\n\t\t}\r\n\t\treturn { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { OnAttackCard } from '../../card.interface';
2
+ export declare const ProdigiousTusker: OnAttackCard;
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ProdigiousTusker = void 0;
4
+ const reference_data_1 = require("@firestone-hs/reference-data");
5
+ const blood_gems_1 = require("../../../simulation/blood-gems");
6
+ exports.ProdigiousTusker = {
7
+ cardIds: ["BG33_430", "BG33_430_G"],
8
+ onAnyMinionAttack: (minion, input) => {
9
+ if ((0, reference_data_1.hasMechanic)(input.gameState.allCards.getCard(input.attacker.cardId), reference_data_1.GameTag.BACON_RALLY)) {
10
+ const mult = minion.cardId === "BG33_430_G" ? 2 : 1;
11
+ (0, blood_gems_1.playBloodGemsOn)(minion, minion, 2 * mult, input.attackingBoard, input.attackingHero, input.gameState);
12
+ }
13
+ return { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };
14
+ },
15
+ };
16
+ //# sourceMappingURL=prodigious-tusker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prodigious-tusker.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/prodigious-tusker.ts"],"names":[],"mappings":";;;AAAA,iEAA6E;AAE7E,+DAAiE;AAIpD,QAAA,gBAAgB,GAAiB;IAC7C,OAAO,EAAE,0BAAwE;IACjF,iBAAiB,EAAE,CAAC,MAAmB,EAAE,KAAoB,EAAE,EAAE;QAChE,IAAI,IAAA,4BAAW,EAAC,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,wBAAO,CAAC,WAAW,CAAC,EAAE;YAC9F,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAAwC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC3E,IAAA,4BAAe,EAAC,MAAM,EAAE,MAAM,EAAE,CAAC,GAAG,IAAI,EAAE,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;SACtG;QACD,OAAO,EAAE,iBAAiB,EAAE,CAAC,EAAE,iBAAiB,EAAE,CAAC,EAAE,CAAC;IACvD,CAAC;CACD,CAAC","sourcesContent":["import { CardIds, GameTag, hasMechanic } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { playBloodGemsOn } from '../../../simulation/blood-gems';\r\nimport { OnAttackInput } from '../../../simulation/on-attack';\r\nimport { OnAttackCard } from '../../card.interface';\r\n\r\nexport const ProdigiousTusker: OnAttackCard = {\r\n\tcardIds: [CardIds.ProdigiousTusker_BG33_430, CardIds.ProdigiousTusker_BG33_430_G],\r\n\tonAnyMinionAttack: (minion: BoardEntity, input: OnAttackInput) => {\r\n\t\tif (hasMechanic(input.gameState.allCards.getCard(input.attacker.cardId), GameTag.BACON_RALLY)) {\r\n\t\t\tconst mult = minion.cardId === CardIds.ProdigiousTusker_BG33_430_G ? 2 : 1;\r\n\t\t\tplayBloodGemsOn(minion, minion, 2 * mult, input.attackingBoard, input.attackingHero, input.gameState);\r\n\t\t}\r\n\t\treturn { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { OnDespawnedCard, OnOtherSpawnedCard, OnSpawnedCard } from '../../card.interface';
2
+ export declare const RaptorElder: OnSpawnedCard & OnOtherSpawnedCard & OnDespawnedCard;
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RaptorElder = void 0;
4
+ const reference_data_1 = require("@firestone-hs/reference-data");
5
+ const utils_1 = require("../../../utils");
6
+ const attackBuff = 1;
7
+ const healthBuff = 1;
8
+ exports.RaptorElder = {
9
+ cardIds: ["BG33_842", "BG33_842_G"],
10
+ onSpawned: (minion, input) => {
11
+ const mult = minion.cardId === "BG33_842_G" ? 2 : 1;
12
+ const baseBuff = input.hero.globalInfo.BeastsSummonedThisCombat * mult;
13
+ const targets = input.board
14
+ .filter((e) => e !== minion)
15
+ .filter((e) => (0, utils_1.hasCorrectTribe)(e, input.hero, reference_data_1.Race.BEAST, input.gameState.anomalies, input.gameState.allCards));
16
+ for (const target of targets) {
17
+ target.attack += attackBuff * baseBuff;
18
+ target.health += healthBuff * baseBuff;
19
+ }
20
+ },
21
+ onDespawned: (minion, input) => {
22
+ const mult = minion.cardId === "BG33_842_G" ? 2 : 1;
23
+ const baseBuff = input.hero.globalInfo.BeastsSummonedThisCombat * mult;
24
+ const targets = input.board
25
+ .filter((e) => e !== minion)
26
+ .filter((e) => (0, utils_1.hasCorrectTribe)(e, input.hero, reference_data_1.Race.BEAST, input.gameState.anomalies, input.gameState.allCards));
27
+ for (const target of targets) {
28
+ target.attack = Math.max(0, target.attack - attackBuff * baseBuff);
29
+ target.health = Math.max(1, target.health - healthBuff * baseBuff);
30
+ }
31
+ },
32
+ onOtherSpawned: (minion, input) => {
33
+ if (!(0, utils_1.hasCorrectTribe)(input.spawned, input.hero, reference_data_1.Race.BEAST, input.gameState.anomalies, input.gameState.allCards)) {
34
+ return;
35
+ }
36
+ const mult = minion.cardId === "BG33_842_G" ? 2 : 1;
37
+ const baseBuff = input.hero.globalInfo.BeastsSummonedThisCombat * mult;
38
+ input.spawned.attack += attackBuff * baseBuff;
39
+ input.spawned.health += healthBuff * baseBuff;
40
+ },
41
+ };
42
+ //# sourceMappingURL=raptor-elder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"raptor-elder.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/raptor-elder.ts"],"names":[],"mappings":"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","sourcesContent":["import { CardIds, Race } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { OnDespawnInput, OnOtherSpawnInput, OnSpawnInput } from '../../../simulation/add-minion-to-board';\r\nimport { hasCorrectTribe } from '../../../utils';\r\nimport { OnDespawnedCard, OnOtherSpawnedCard, OnSpawnedCard } from '../../card.interface';\r\n\r\nconst attackBuff = 1;\r\nconst healthBuff = 1;\r\n\r\nexport const RaptorElder: OnSpawnedCard & OnOtherSpawnedCard & OnDespawnedCard = {\r\n\tcardIds: [CardIds.RaptorElder_BG33_842, CardIds.RaptorElder_BG33_842_G],\r\n\tonSpawned: (minion: BoardEntity, input: OnSpawnInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.RaptorElder_BG33_842_G ? 2 : 1;\r\n\t\tconst baseBuff = input.hero.globalInfo.BeastsSummonedThisCombat * mult;\r\n\t\tconst targets = input.board\r\n\t\t\t.filter((e) => e !== minion)\r\n\t\t\t.filter((e) =>\r\n\t\t\t\thasCorrectTribe(e, input.hero, Race.BEAST, input.gameState.anomalies, input.gameState.allCards),\r\n\t\t\t);\r\n\t\tfor (const target of targets) {\r\n\t\t\ttarget.attack += attackBuff * baseBuff;\r\n\t\t\ttarget.health += healthBuff * baseBuff;\r\n\t\t}\r\n\t},\r\n\tonDespawned: (minion: BoardEntity, input: OnDespawnInput) => {\r\n\t\tconst mult = minion.cardId === CardIds.RaptorElder_BG33_842_G ? 2 : 1;\r\n\t\tconst baseBuff = input.hero.globalInfo.BeastsSummonedThisCombat * mult;\r\n\t\tconst targets = input.board\r\n\t\t\t.filter((e) => e !== minion)\r\n\t\t\t.filter((e) =>\r\n\t\t\t\thasCorrectTribe(e, input.hero, Race.BEAST, input.gameState.anomalies, input.gameState.allCards),\r\n\t\t\t);\r\n\t\tfor (const target of targets) {\r\n\t\t\ttarget.attack = Math.max(0, target.attack - attackBuff * baseBuff);\r\n\t\t\ttarget.health = Math.max(1, target.health - healthBuff * baseBuff);\r\n\t\t}\r\n\t},\r\n\tonOtherSpawned: (minion: BoardEntity, input: OnOtherSpawnInput) => {\r\n\t\tif (\r\n\t\t\t!hasCorrectTribe(input.spawned, input.hero, Race.BEAST, input.gameState.anomalies, input.gameState.allCards)\r\n\t\t) {\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tconst mult = minion.cardId === CardIds.RaptorElder_BG33_842_G ? 2 : 1;\r\n\t\tconst baseBuff = input.hero.globalInfo.BeastsSummonedThisCombat * mult;\r\n\t\tinput.spawned.attack += attackBuff * baseBuff;\r\n\t\tinput.spawned.health += healthBuff * baseBuff;\r\n\t},\r\n};\r\n"]}
@@ -0,0 +1,2 @@
1
+ import { OnAttackCard } from '../../card.interface';
2
+ export declare const RazorfenVineweaver: OnAttackCard;
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RazorfenVineweaver = void 0;
4
+ const blood_gems_1 = require("../../../simulation/blood-gems");
5
+ exports.RazorfenVineweaver = {
6
+ cardIds: ["BG33_883", "BG33_883_G"],
7
+ onAnyMinionAttack: (minion, input) => {
8
+ if (input.attacker !== minion) {
9
+ return { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };
10
+ }
11
+ const mult = minion.cardId === "BG33_883_G" ? 2 : 1;
12
+ (0, blood_gems_1.playBloodGemsOn)(minion, minion, 3 * mult, input.attackingBoard, input.attackingHero, input.gameState);
13
+ return { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };
14
+ },
15
+ };
16
+ //# sourceMappingURL=razorfen-vineweaver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"razorfen-vineweaver.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/razorfen-vineweaver.ts"],"names":[],"mappings":";;;AAEA,+DAAiE;AAIpD,QAAA,kBAAkB,GAAiB;IAC/C,OAAO,EAAE,0BAA4E;IACrF,iBAAiB,EAAE,CAAC,MAAmB,EAAE,KAAoB,EAAE,EAAE;QAChE,IAAI,KAAK,CAAC,QAAQ,KAAK,MAAM,EAAE;YAC9B,OAAO,EAAE,iBAAiB,EAAE,CAAC,EAAE,iBAAiB,EAAE,CAAC,EAAE,CAAC;SACtD;QAED,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,iBAA0C,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7E,IAAA,4BAAe,EAAC,MAAM,EAAE,MAAM,EAAE,CAAC,GAAG,IAAI,EAAE,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QACtG,OAAO,EAAE,iBAAiB,EAAE,CAAC,EAAE,iBAAiB,EAAE,CAAC,EAAE,CAAC;IACvD,CAAC;CACD,CAAC","sourcesContent":["import { CardIds } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { playBloodGemsOn } from '../../../simulation/blood-gems';\r\nimport { OnAttackInput } from '../../../simulation/on-attack';\r\nimport { OnAttackCard } from '../../card.interface';\r\n\r\nexport const RazorfenVineweaver: OnAttackCard = {\r\n\tcardIds: [CardIds.RazorfenVineweaver_BG33_883, CardIds.RazorfenVineweaver_BG33_883_G],\r\n\tonAnyMinionAttack: (minion: BoardEntity, input: OnAttackInput) => {\r\n\t\tif (input.attacker !== minion) {\r\n\t\t\treturn { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };\r\n\t\t}\r\n\r\n\t\tconst mult = minion.cardId === CardIds.RazorfenVineweaver_BG33_883_G ? 2 : 1;\r\n\t\tplayBloodGemsOn(minion, minion, 3 * mult, input.attackingBoard, input.attackingHero, input.gameState);\r\n\t\treturn { dmgDoneByAttacker: 0, dmgDoneByDefender: 0 };\r\n\t},\r\n};\r\n"]}
@@ -7,7 +7,7 @@ const utils_1 = require("../../../utils");
7
7
  exports.RedWhelp = {
8
8
  startOfCombat: (minion, input) => {
9
9
  const damage = input.playerBoardBefore.filter((entity) => (0, utils_1.hasCorrectTribe)(entity, input.playerEntity, reference_data_1.Race.DRAGON, input.gameState.anomalies, input.gameState.allCards)).length;
10
- const loops = minion.cardId === "TB_BaconUps_102" ? 2 : 1;
10
+ const loops = 1;
11
11
  for (let i = 0; i < loops; i++) {
12
12
  (0, attack_1.dealDamageToRandomEnemy)(input.opponentBoard, input.opponentEntity, minion, damage, input.playerBoard, input.playerEntity, input.gameState);
13
13
  }
@@ -1 +1 @@
1
- {"version":3,"file":"red-whelp.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/red-whelp.ts"],"names":[],"mappings":";;;AAAA,iEAA6D;AAE7D,uDAAqE;AAErE,0CAAiD;AAEpC,QAAA,QAAQ,GAAG;IACvB,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QACvD,MAAM,MAAM,GAAG,KAAK,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CACxD,IAAA,uBAAe,EACd,MAAM,EACN,KAAK,CAAC,YAAY,EAClB,qBAAI,CAAC,MAAM,EACX,KAAK,CAAC,SAAS,CAAC,SAAS,EACzB,KAAK,CAAC,SAAS,CAAC,QAAQ,CACxB,CACD,CAAC,MAAM,CAAC;QACT,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,sBAAqC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACzE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE;YAC/B,IAAA,gCAAuB,EACtB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,cAAc,EACpB,MAAM,EACN,MAAM,EACN,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, Race } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { dealDamageToRandomEnemy } from '../../../simulation/attack';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { hasCorrectTribe } from '../../../utils';\r\n\r\nexport const RedWhelp = {\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst damage = input.playerBoardBefore.filter((entity) =>\r\n\t\t\thasCorrectTribe(\r\n\t\t\t\tentity,\r\n\t\t\t\tinput.playerEntity,\r\n\t\t\t\tRace.DRAGON,\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).length;\r\n\t\tconst loops = minion.cardId === CardIds.RedWhelp_TB_BaconUps_102 ? 2 : 1;\r\n\t\tfor (let i = 0; i < loops; i++) {\r\n\t\t\tdealDamageToRandomEnemy(\r\n\t\t\t\tinput.opponentBoard,\r\n\t\t\t\tinput.opponentEntity,\r\n\t\t\t\tminion,\r\n\t\t\t\tdamage,\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"]}
1
+ {"version":3,"file":"red-whelp.js","sourceRoot":"","sources":["../../../../src/cards/impl/minion/red-whelp.ts"],"names":[],"mappings":";;;AAAA,iEAAoD;AAEpD,uDAAqE;AAErE,0CAAiD;AAEpC,QAAA,QAAQ,GAAG;IACvB,aAAa,EAAE,CAAC,MAAmB,EAAE,KAAe,EAAE,EAAE;QACvD,MAAM,MAAM,GAAG,KAAK,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CACxD,IAAA,uBAAe,EACd,MAAM,EACN,KAAK,CAAC,YAAY,EAClB,qBAAI,CAAC,MAAM,EACX,KAAK,CAAC,SAAS,CAAC,SAAS,EACzB,KAAK,CAAC,SAAS,CAAC,QAAQ,CACxB,CACD,CAAC,MAAM,CAAC;QACT,MAAM,KAAK,GAAG,CAAC,CAAC;QAChB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE;YAC/B,IAAA,gCAAuB,EACtB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,cAAc,EACpB,MAAM,EACN,MAAM,EACN,KAAK,CAAC,WAAW,EACjB,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,SAAS,CACf,CAAC;SACF;QACD,OAAO,IAAI,CAAC;IACb,CAAC;CACD,CAAC","sourcesContent":["import { Race } from '@firestone-hs/reference-data';\r\nimport { BoardEntity } from '../../../board-entity';\r\nimport { dealDamageToRandomEnemy } from '../../../simulation/attack';\r\nimport { SoCInput } from '../../../simulation/start-of-combat/start-of-combat-input';\r\nimport { hasCorrectTribe } from '../../../utils';\r\n\r\nexport const RedWhelp = {\r\n\tstartOfCombat: (minion: BoardEntity, input: SoCInput) => {\r\n\t\tconst damage = input.playerBoardBefore.filter((entity) =>\r\n\t\t\thasCorrectTribe(\r\n\t\t\t\tentity,\r\n\t\t\t\tinput.playerEntity,\r\n\t\t\t\tRace.DRAGON,\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).length;\r\n\t\tconst loops = 1; //minion.cardId === CardIds.RedWhelp_TB_BaconUps_102 ? 2 : 1;\r\n\t\tfor (let i = 0; i < loops; i++) {\r\n\t\t\tdealDamageToRandomEnemy(\r\n\t\t\t\tinput.opponentBoard,\r\n\t\t\t\tinput.opponentEntity,\r\n\t\t\t\tminion,\r\n\t\t\t\tdamage,\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"]}