From 372b088f2bd5db22f2fb5e08604ce241b2ead33e Mon Sep 17 00:00:00 2001
From: theelk801 <theelk801@gmail.com>
Date: Sat, 1 Apr 2023 18:45:26 -0400
Subject: [PATCH] [MOM] Implement Omen Hawker

---
 Mage.Sets/src/mage/cards/o/OmenHawker.java    | 87 +++++++++++++++++++
 .../src/mage/sets/MarchOfTheMachine.java      |  1 +
 2 files changed, 88 insertions(+)
 create mode 100644 Mage.Sets/src/mage/cards/o/OmenHawker.java

diff --git a/Mage.Sets/src/mage/cards/o/OmenHawker.java b/Mage.Sets/src/mage/cards/o/OmenHawker.java
new file mode 100644
index 0000000000..47d9f6f72a
--- /dev/null
+++ b/Mage.Sets/src/mage/cards/o/OmenHawker.java
@@ -0,0 +1,87 @@
+package mage.cards.o;
+
+import mage.ConditionalMana;
+import mage.MageInt;
+import mage.Mana;
+import mage.abilities.Ability;
+import mage.abilities.condition.Condition;
+import mage.abilities.costs.Cost;
+import mage.abilities.mana.ConditionalColoredManaAbility;
+import mage.abilities.mana.builder.ConditionalManaBuilder;
+import mage.abilities.mana.conditional.ManaCondition;
+import mage.cards.CardImpl;
+import mage.cards.CardSetInfo;
+import mage.constants.AbilityType;
+import mage.constants.CardType;
+import mage.constants.SubType;
+import mage.game.Game;
+
+import java.util.UUID;
+
+/**
+ * @author TheElk801
+ */
+public final class OmenHawker extends CardImpl {
+
+    public OmenHawker(UUID ownerId, CardSetInfo setInfo) {
+        super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{U}");
+
+        this.subtype.add(SubType.CEPHALID);
+        this.subtype.add(SubType.ADVISOR);
+        this.power = new MageInt(1);
+        this.toughness = new MageInt(1);
+
+        // {T}: Add {C}{U}. Spend this many only to activate abilities.
+        this.addAbility(new ConditionalColoredManaAbility(
+                new Mana(0, 1, 0, 0, 0, 0, 0, 1), new OmenHawkerManaBuilder()
+        ));
+    }
+
+    private OmenHawker(final OmenHawker card) {
+        super(card);
+    }
+
+    @Override
+    public OmenHawker copy() {
+        return new OmenHawker(this);
+    }
+}
+
+class OmenHawkerManaBuilder extends ConditionalManaBuilder {
+
+    @Override
+    public ConditionalMana build(Object... options) {
+        return new OmenHawkerConditionalMana(this.mana);
+    }
+
+    @Override
+    public String getRule() {
+        return "Spend this mana only to activate abilities";
+    }
+}
+
+class OmenHawkerConditionalMana extends ConditionalMana {
+
+    OmenHawkerConditionalMana(Mana mana) {
+        super(mana);
+        staticText = "Spend this mana only to activate abilities";
+        addCondition(new OmenHawkerManaCondition());
+    }
+}
+
+class OmenHawkerManaCondition extends ManaCondition implements Condition {
+
+    @Override
+    public boolean apply(Game game, Ability source) {
+        if (source != null) {
+            return source.getAbilityType() == AbilityType.MANA
+                    || source.getAbilityType() == AbilityType.ACTIVATED;
+        }
+        return false;
+    }
+
+    @Override
+    public boolean apply(Game game, Ability source, UUID originalId, Cost costsToPay) {
+        return apply(game, source);
+    }
+}
diff --git a/Mage.Sets/src/mage/sets/MarchOfTheMachine.java b/Mage.Sets/src/mage/sets/MarchOfTheMachine.java
index 498d4015ad..7f973954e4 100644
--- a/Mage.Sets/src/mage/sets/MarchOfTheMachine.java
+++ b/Mage.Sets/src/mage/sets/MarchOfTheMachine.java
@@ -53,6 +53,7 @@ public final class MarchOfTheMachine extends ExpansionSet {
         cards.add(new SetCardInfo("Mountain", 280, Rarity.LAND, mage.cards.basiclands.Mountain.class, NON_FULL_USE_VARIOUS));
         cards.add(new SetCardInfo("Mutagen Connoisseur", 248, Rarity.UNCOMMON, mage.cards.m.MutagenConnoisseur.class));
         cards.add(new SetCardInfo("Negate", 68, Rarity.COMMON, mage.cards.n.Negate.class));
+        cards.add(new SetCardInfo("Omen Hawker", 70, Rarity.UNCOMMON, mage.cards.o.OmenHawker.class));
         cards.add(new SetCardInfo("Oracle of Tragedy", 71, Rarity.UNCOMMON, mage.cards.o.OracleOfTragedy.class));
         cards.add(new SetCardInfo("Phyrexian Gargantua", 121, Rarity.UNCOMMON, mage.cards.p.PhyrexianGargantua.class));
         cards.add(new SetCardInfo("Phyrexian Pegasus", 324, Rarity.COMMON, mage.cards.p.PhyrexianPegasus.class));