made essences work

This commit is contained in:
0x01fe 2025-02-14 20:06:12 -06:00
parent d897688ab4
commit ad57acf11a
8 changed files with 90 additions and 14 deletions

View File

@ -3,7 +3,7 @@
<modelVersion>4.0.0</modelVersion>
<groupId>net.hexa</groupId>
<artifactId>EconPlugn</artifactId>
<artifactId>MythicItems</artifactId>
<version>1.0-SNAPSHOT</version>
<repositories>

View File

@ -1,13 +1,12 @@
package net.hexa.MythicItems;
import net.hexa.MythicItems.Mythics.MythicEssence;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import org.bukkit.inventory.ItemStack;
import net.hexa.MythicItems.Mythics.RockCracker;
public class CommandMythicEssence implements CommandExecutor {
@Override
@ -15,7 +14,7 @@ public class CommandMythicEssence implements CommandExecutor {
if (sender instanceof Player) {
Player player = (Player) sender;
ItemStack item = new RockCracker().item;
ItemStack item = new MythicEssence().item;
player.getInventory().addItem(item);
}

View File

@ -1,11 +1,15 @@
package net.hexa.MythicItems;
import net.hexa.MythicItems.Mythics.MythicEssence;
import net.hexa.MythicItems.Mythics.MythicItem;
import org.bukkit.Bukkit;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.block.Action;
import org.bukkit.event.block.BlockBreakEvent;
import org.bukkit.event.player.PlayerInteractEvent;
import org.bukkit.inventory.ItemStack;
public class MythicListener implements Listener {
@ -23,4 +27,30 @@ public class MythicListener implements Listener {
}
}
@EventHandler
public void onPlayerUse(PlayerInteractEvent event) {
Bukkit.getServer().getPluginManager().getPlugin("MythicItems").getLogger().info("Action done" + event.getAction().toString());
if (event.getAction() == Action.RIGHT_CLICK_AIR || event.getAction() == Action.RIGHT_CLICK_BLOCK) {
Bukkit.getServer().getPluginManager().getPlugin("MythicItems").getLogger().info("Action done2" + event.getAction().toString());
Player player = event.getPlayer();
ItemStack item = player.getInventory().getItemInMainHand();
Bukkit.getServer().getPluginManager().getPlugin("MythicItems").getLogger()
.info(item.toString());
if (MythicItem.isMythic(item)) {
Bukkit.getServer().getPluginManager().getPlugin("MythicItems").getLogger()
.info("item was mythic with id " + MythicItem.getMythicId(item));
if (MythicItem.getMythicId(item) == 0) {
ItemStack mythicReward = MythicEssence.rollMythic();
player.getInventory().remove(item);
player.getInventory().addItem(mythicReward);
}
}
}
}
}

View File

@ -1,8 +1,11 @@
package net.hexa.MythicItems.Mythics;
import net.hexa.MythicItems.MythicItems;
import org.bukkit.Bukkit;
import org.bukkit.NamespacedKey;
import org.bukkit.plugin.Plugin;
public class Constants {
public static NamespacedKey mythic_key = new NamespacedKey(new MythicItems(), "mythic-id");
public static Plugin plugin = Bukkit.getServer().getPluginManager().getPlugin("MythicItems");
public static NamespacedKey mythic_key = new NamespacedKey(plugin, "mythic-id");
}

View File

@ -0,0 +1,39 @@
package net.hexa.MythicItems.Mythics;
import org.bukkit.Material;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.meta.ItemMeta;
import java.util.Arrays;
import java.util.Random;
public class MythicEssence extends MythicItem {
private static final Random random = new Random();
public MythicEssence() {
item = new ItemStack(Material.CLAY_BALL);
item.addUnsafeEnchantment(Enchantment.FORTUNE, 7);
ItemMeta itemData = item.getItemMeta();
itemData.setItemName("§4Mythic Essence");
itemData.setLore(Arrays.asList("§o§aMaybe this will give you something nice?"));
item.setItemMeta(itemData);
setMythicId(0);
}
public static ItemStack rollMythic() {
int mythic_id = random.nextInt(2) + 1;
switch (mythic_id) {
case 1:
return new Terra().item;
case 2:
return new RockCracker().item;
}
return new ItemStack(Material.GRAVEL);
}
}

View File

@ -1,6 +1,7 @@
package net.hexa.MythicItems.Mythics;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.meta.ItemMeta;
import org.bukkit.persistence.PersistentDataContainer;
import org.bukkit.persistence.PersistentDataType;
@ -22,7 +23,8 @@ public abstract class MythicItem {
}
protected void setMythicId(int id) {
PersistentDataContainer itemData = item.getItemMeta().getPersistentDataContainer();
itemData.set(Constants.mythic_key, PersistentDataType.INTEGER, id);
ItemMeta itemData = item.getItemMeta();
itemData.getPersistentDataContainer().set(Constants.mythic_key, PersistentDataType.INTEGER, id);
this.item.setItemMeta(itemData);
}
}

View File

@ -3,6 +3,7 @@ package net.hexa.MythicItems.Mythics;
import org.bukkit.Material;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.meta.ItemMeta;
import org.bukkit.persistence.PersistentDataType;
import java.util.Arrays;
@ -14,11 +15,14 @@ public class RockCracker extends MythicItem {
item.addUnsafeEnchantment(Enchantment.EFFICIENCY, 9);
item.addUnsafeEnchantment(Enchantment.UNBREAKING, 10);
item.getItemMeta().setUnbreakable(true);
item.getItemMeta().setItemName("Rock Cracker");
item.getItemMeta().setLore(Arrays.asList("and the land thrashes in furious pain..."));
item.getItemMeta().setEnchantable(0);
ItemMeta itemData = item.getItemMeta();
setMythicId(1);
itemData.setUnbreakable(true);
itemData.setItemName("Rock Cracker");
itemData.setLore(Arrays.asList("and the land thrashes in furious pain..."));
item.setItemMeta(itemData);
this.setMythicId(1);
}
}

View File

@ -17,9 +17,8 @@ public class Terra extends MythicItem {
ItemMeta meta = item.getItemMeta();
meta.setUnbreakable(true);
meta.setDisplayName("Terra");
meta.setItemName("Terra");
meta.setLore(Arrays.asList("All will eventually return to Terra."));
meta.setEnchantable(0);
item.setItemMeta(meta);
setMythicId(2);