From 8d9a62f259d08db996f97ddbc8958b37d8dde4ac Mon Sep 17 00:00:00 2001 From: Evan Kranzler Date: Thu, 10 Sep 2020 12:12:13 -0400 Subject: [PATCH] [ZNR] Implemented Coveted Prize --- Mage.Sets/src/mage/cards/c/CovetedPrize.java | 49 +++++++++++++++++++ Mage.Sets/src/mage/sets/ZendikarRising.java | 1 + .../condition/common/FullPartyCondition.java | 2 - 3 files changed, 50 insertions(+), 2 deletions(-) create mode 100644 Mage.Sets/src/mage/cards/c/CovetedPrize.java diff --git a/Mage.Sets/src/mage/cards/c/CovetedPrize.java b/Mage.Sets/src/mage/cards/c/CovetedPrize.java new file mode 100644 index 00000000000..c81c6c85361 --- /dev/null +++ b/Mage.Sets/src/mage/cards/c/CovetedPrize.java @@ -0,0 +1,49 @@ +package mage.cards.c; + +import mage.abilities.common.SimpleStaticAbility; +import mage.abilities.condition.common.FullPartyCondition; +import mage.abilities.decorator.ConditionalOneShotEffect; +import mage.abilities.dynamicvalue.common.PartyCount; +import mage.abilities.effects.common.cost.CastWithoutPayingManaCostEffect; +import mage.abilities.effects.common.cost.SpellCostReductionForEachSourceEffect; +import mage.abilities.effects.common.search.SearchLibraryPutInHandEffect; +import mage.abilities.hint.common.PartyCountHint; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.Zone; +import mage.target.common.TargetCardInLibrary; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class CovetedPrize extends CardImpl { + + public CovetedPrize(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.SORCERY}, "{4}{B}"); + + // This spell costs {1} less to cast for each creature in your party. + this.addAbility(new SimpleStaticAbility( + Zone.ALL, new SpellCostReductionForEachSourceEffect(1, PartyCount.instance) + ).addHint(PartyCountHint.instance)); + + // Search your library for a card, put it into your hand, then shuffle your library. If you have a full party, you may cast a spell with converted mana cost 4 or less from your hand without paying its mana cost. + this.getSpellAbility().addEffect(new SearchLibraryPutInHandEffect(new TargetCardInLibrary())); + this.getSpellAbility().addEffect(new ConditionalOneShotEffect( + new CastWithoutPayingManaCostEffect(4), + FullPartyCondition.instance, "If you have a full party, " + + "you may cast a spell with converted mana cost 4 or less from your hand without paying its mana cost." + )); + } + + private CovetedPrize(final CovetedPrize card) { + super(card); + } + + @Override + public CovetedPrize copy() { + return new CovetedPrize(this); + } +} diff --git a/Mage.Sets/src/mage/sets/ZendikarRising.java b/Mage.Sets/src/mage/sets/ZendikarRising.java index 82ac0bb966c..11653601799 100644 --- a/Mage.Sets/src/mage/sets/ZendikarRising.java +++ b/Mage.Sets/src/mage/sets/ZendikarRising.java @@ -147,6 +147,7 @@ public final class ZendikarRising extends ExpansionSet { cards.add(new SetCardInfo("Cliffhaven Sell-Sword", 8, Rarity.COMMON, mage.cards.c.CliffhavenSellSword.class)); cards.add(new SetCardInfo("Concerted Defense", 52, Rarity.UNCOMMON, mage.cards.c.ConcertedDefense.class)); cards.add(new SetCardInfo("Coralhelm Chronicler", 54, Rarity.RARE, mage.cards.c.CoralhelmChronicler.class)); + cards.add(new SetCardInfo("Coveted Prize", 95, Rarity.RARE, mage.cards.c.CovetedPrize.class)); cards.add(new SetCardInfo("Cragcrown Pathway", 261, Rarity.RARE, mage.cards.c.CragcrownPathway.class)); cards.add(new SetCardInfo("Cragplate Baloth", 183, Rarity.RARE, mage.cards.c.CragplateBaloth.class)); cards.add(new SetCardInfo("Crawling Barrens", 262, Rarity.RARE, mage.cards.c.CrawlingBarrens.class)); diff --git a/Mage/src/main/java/mage/abilities/condition/common/FullPartyCondition.java b/Mage/src/main/java/mage/abilities/condition/common/FullPartyCondition.java index 27cb9a036a3..885640c2caa 100644 --- a/Mage/src/main/java/mage/abilities/condition/common/FullPartyCondition.java +++ b/Mage/src/main/java/mage/abilities/condition/common/FullPartyCondition.java @@ -3,8 +3,6 @@ package mage.abilities.condition.common; import mage.abilities.Ability; import mage.abilities.condition.Condition; import mage.abilities.dynamicvalue.common.PartyCount; -import mage.abilities.keyword.EvokeAbility; -import mage.cards.Card; import mage.game.Game; /**