mirror of
https://github.com/correl/mage.git
synced 2024-11-21 19:18:40 +00:00
[LTC] Implement Model of Unity
This commit is contained in:
parent
87fc0ec9e9
commit
19a9a94817
2 changed files with 77 additions and 0 deletions
76
Mage.Sets/src/mage/cards/m/ModelOfUnity.java
Normal file
76
Mage.Sets/src/mage/cards/m/ModelOfUnity.java
Normal file
|
@ -0,0 +1,76 @@
|
|||
package mage.cards.m;
|
||||
|
||||
import mage.abilities.Ability;
|
||||
import mage.abilities.common.FinishVotingTriggeredAbility;
|
||||
import mage.abilities.effects.OneShotEffect;
|
||||
import mage.abilities.mana.AnyColorManaAbility;
|
||||
import mage.cards.CardImpl;
|
||||
import mage.cards.CardSetInfo;
|
||||
import mage.constants.CardType;
|
||||
import mage.constants.Outcome;
|
||||
import mage.game.Game;
|
||||
import mage.players.Player;
|
||||
|
||||
import java.util.Set;
|
||||
import java.util.UUID;
|
||||
|
||||
/**
|
||||
* @author TheElk801
|
||||
*/
|
||||
public final class ModelOfUnity extends CardImpl {
|
||||
|
||||
public ModelOfUnity(UUID ownerId, CardSetInfo setInfo) {
|
||||
super(ownerId, setInfo, new CardType[]{CardType.ARTIFACT}, "{3}");
|
||||
|
||||
// Whenever players finish voting, you and each opponent who voted for a choice you voted for may scry 2.
|
||||
this.addAbility(new FinishVotingTriggeredAbility(new ModelOfUnityEffect()));
|
||||
|
||||
// {T}: Add one mana of any color.
|
||||
this.addAbility(new AnyColorManaAbility());
|
||||
}
|
||||
|
||||
private ModelOfUnity(final ModelOfUnity card) {
|
||||
super(card);
|
||||
}
|
||||
|
||||
@Override
|
||||
public ModelOfUnity copy() {
|
||||
return new ModelOfUnity(this);
|
||||
}
|
||||
}
|
||||
|
||||
class ModelOfUnityEffect extends OneShotEffect {
|
||||
|
||||
ModelOfUnityEffect() {
|
||||
super(Outcome.Benefit);
|
||||
staticText = "you and each opponent who voted for a choice you voted for may scry 2";
|
||||
}
|
||||
|
||||
private ModelOfUnityEffect(final ModelOfUnityEffect effect) {
|
||||
super(effect);
|
||||
}
|
||||
|
||||
@Override
|
||||
public ModelOfUnityEffect copy() {
|
||||
return new ModelOfUnityEffect(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean apply(Game game, Ability source) {
|
||||
Player controller = game.getPlayer(source.getControllerId());
|
||||
if (controller != null && controller.chooseUse(outcome, "Scry 2?", source, game)) {
|
||||
controller.scry(2, source, game);
|
||||
}
|
||||
Set<UUID> playerIds = (Set<UUID>) getValue("votedAgainst");
|
||||
for (UUID opponentId : game.getOpponents(source.getControllerId())) {
|
||||
if (playerIds.contains(opponentId)) {
|
||||
continue;
|
||||
}
|
||||
Player player = game.getPlayer(opponentId);
|
||||
if (player != null && player.chooseUse(outcome, "Scry 2?", source, game)) {
|
||||
player.loseLife(2, game, source, false);
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
}
|
|
@ -152,6 +152,7 @@ public final class TalesOfMiddleEarthCommander extends ExpansionSet {
|
|||
cards.add(new SetCardInfo("Merry, Warden of Isengard", 61, Rarity.RARE, mage.cards.m.MerryWardenOfIsengard.class));
|
||||
cards.add(new SetCardInfo("Minamo, School at Water's Edge", 369, Rarity.MYTHIC, mage.cards.m.MinamoSchoolAtWatersEdge.class));
|
||||
cards.add(new SetCardInfo("Mind Stone", 282, Rarity.UNCOMMON, mage.cards.m.MindStone.class));
|
||||
cards.add(new SetCardInfo("Model of Unity", 78, Rarity.RARE, mage.cards.m.ModelOfUnity.class));
|
||||
cards.add(new SetCardInfo("Mortify", 269, Rarity.UNCOMMON, mage.cards.m.Mortify.class));
|
||||
cards.add(new SetCardInfo("Mouth of Ronom", 370, Rarity.MYTHIC, mage.cards.m.MouthOfRonom.class));
|
||||
cards.add(new SetCardInfo("Murmuring Bosk", 320, Rarity.RARE, mage.cards.m.MurmuringBosk.class));
|
||||
|
|
Loading…
Reference in a new issue