diff --git a/Mage.Sets/src/mage/cards/r/RansomNote.java b/Mage.Sets/src/mage/cards/r/RansomNote.java new file mode 100644 index 00000000000..764d157ed0d --- /dev/null +++ b/Mage.Sets/src/mage/cards/r/RansomNote.java @@ -0,0 +1,58 @@ +package mage.cards.r; + +import mage.abilities.Ability; +import mage.abilities.Mode; +import mage.abilities.common.EntersBattlefieldTriggeredAbility; +import mage.abilities.common.SimpleActivatedAbility; +import mage.abilities.costs.common.SacrificeSourceCost; +import mage.abilities.costs.mana.GenericManaCost; +import mage.abilities.dynamicvalue.common.StaticValue; +import mage.abilities.effects.common.DrawCardSourceControllerEffect; +import mage.abilities.effects.common.combat.GoadTargetEffect; +import mage.abilities.effects.keyword.ManifestEffect; +import mage.abilities.effects.keyword.SurveilEffect; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.target.common.TargetCreaturePermanent; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class RansomNote extends CardImpl { + + public RansomNote(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.ARTIFACT}, "{1}"); + + this.subtype.add(SubType.CLUE); + + // When Ransom Note enters the battlefield, surveil 1. + this.addAbility(new EntersBattlefieldTriggeredAbility(new SurveilEffect(1))); + + // {2}, Sacrifice Ransom Note: Choose one -- + // * Cloak the top card of your library. + Ability ability = new SimpleActivatedAbility( + new ManifestEffect(StaticValue.get(1), false, true), new GenericManaCost(2) + ); + ability.addCost(new SacrificeSourceCost()); + + // * Goad target creature. + ability.addMode(new Mode(new GoadTargetEffect()).addTarget(new TargetCreaturePermanent())); + + // * Draw a card. + ability.addMode(new Mode(new DrawCardSourceControllerEffect(1))); + this.addAbility(ability); + } + + private RansomNote(final RansomNote card) { + super(card); + } + + @Override + public RansomNote copy() { + return new RansomNote(this); + } +} diff --git a/Mage.Sets/src/mage/sets/MurdersAtKarlovManorCommander.java b/Mage.Sets/src/mage/sets/MurdersAtKarlovManorCommander.java index 2528a103105..067dd103e5c 100644 --- a/Mage.Sets/src/mage/sets/MurdersAtKarlovManorCommander.java +++ b/Mage.Sets/src/mage/sets/MurdersAtKarlovManorCommander.java @@ -215,6 +215,7 @@ public final class MurdersAtKarlovManorCommander extends ExpansionSet { cards.add(new SetCardInfo("Prisoner's Dilemma", 34, Rarity.RARE, mage.cards.p.PrisonersDilemma.class)); cards.add(new SetCardInfo("Promise of Loyalty", 79, Rarity.RARE, mage.cards.p.PromiseOfLoyalty.class)); cards.add(new SetCardInfo("Psychosis Crawler", 234, Rarity.RARE, mage.cards.p.PsychosisCrawler.class)); + cards.add(new SetCardInfo("Ransom Note", 45, Rarity.RARE, mage.cards.r.RansomNote.class)); cards.add(new SetCardInfo("Ravenous Chupacabra", 136, Rarity.UNCOMMON, mage.cards.r.RavenousChupacabra.class)); cards.add(new SetCardInfo("Reanimate", 137, Rarity.RARE, mage.cards.r.Reanimate.class)); cards.add(new SetCardInfo("Redemption Arc", 13, Rarity.RARE, mage.cards.r.RedemptionArc.class)); diff --git a/Mage/src/main/java/mage/abilities/effects/keyword/ManifestEffect.java b/Mage/src/main/java/mage/abilities/effects/keyword/ManifestEffect.java index 459acaca2ad..aba3e39d53c 100644 --- a/Mage/src/main/java/mage/abilities/effects/keyword/ManifestEffect.java +++ b/Mage/src/main/java/mage/abilities/effects/keyword/ManifestEffect.java @@ -82,7 +82,7 @@ public class ManifestEffect extends OneShotEffect { this(amount, isPlural, false); } - private ManifestEffect(DynamicValue amount, boolean isPlural, boolean cloakNotManifest) { + public ManifestEffect(DynamicValue amount, boolean isPlural, boolean cloakNotManifest) { super(Outcome.PutCreatureInPlay); this.amount = amount; this.isPlural = isPlural;