mirror of
https://github.com/Auxilor/EcoEnchants.git
synced 2024-11-26 15:45:12 +01:00
Made soft touch
This commit is contained in:
parent
62b7df59c4
commit
3c1d7f88d6
7
eco-extensions/softtouch/build.gradle
Normal file
7
eco-extensions/softtouch/build.gradle
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
group 'com.willfp'
|
||||||
|
version '1.0.0'
|
||||||
|
description = 'Soft Touch Extension'
|
||||||
|
|
||||||
|
shadowJar {
|
||||||
|
archiveFileName = project.getDescription() + " v" + project.version + ".jar"
|
||||||
|
}
|
@ -0,0 +1,51 @@
|
|||||||
|
package com.willfp.ecoenchants.softtouch;
|
||||||
|
|
||||||
|
|
||||||
|
import com.willfp.eco.core.drops.DropQueue;
|
||||||
|
import com.willfp.ecoenchants.enchantments.EcoEnchant;
|
||||||
|
import com.willfp.ecoenchants.enchantments.meta.EnchantmentType;
|
||||||
|
import com.willfp.ecoenchants.enchantments.util.EnchantmentUtils;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.block.Block;
|
||||||
|
import org.bukkit.block.CreatureSpawner;
|
||||||
|
import org.bukkit.entity.EntityType;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.block.BlockBreakEvent;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.BlockStateMeta;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
public class SoftTouch extends EcoEnchant {
|
||||||
|
public SoftTouch() {
|
||||||
|
super("soft_touch", EnchantmentType.NORMAL);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onBlockBreak(@NotNull final Player player,
|
||||||
|
@NotNull final Block block,
|
||||||
|
final int level,
|
||||||
|
@NotNull final BlockBreakEvent event) {
|
||||||
|
if (!EnchantmentUtils.passedChance(this, level)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(block.getState() instanceof CreatureSpawner spawner)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
EntityType type = spawner.getSpawnedType();
|
||||||
|
|
||||||
|
event.setDropItems(false);
|
||||||
|
event.setExpToDrop(0);
|
||||||
|
|
||||||
|
ItemStack itemStack = new ItemStack(Material.SPAWNER);
|
||||||
|
BlockStateMeta meta = (BlockStateMeta) itemStack.getItemMeta();
|
||||||
|
assert meta != null;
|
||||||
|
meta.setBlockState(spawner);
|
||||||
|
itemStack.setItemMeta(meta);
|
||||||
|
|
||||||
|
new DropQueue(player)
|
||||||
|
.addItem(itemStack)
|
||||||
|
.push();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,24 @@
|
|||||||
|
package com.willfp.ecoenchants.softtouch;
|
||||||
|
|
||||||
|
import com.willfp.eco.core.EcoPlugin;
|
||||||
|
import com.willfp.eco.core.extensions.Extension;
|
||||||
|
import com.willfp.ecoenchants.enchantments.EcoEnchant;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
public class SoftTouchMain extends Extension {
|
||||||
|
public static final EcoEnchant SOFT_TOUCH = new SoftTouch();
|
||||||
|
|
||||||
|
public SoftTouchMain(@NotNull final EcoPlugin plugin) {
|
||||||
|
super(plugin);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onEnable() {
|
||||||
|
// Handled by super
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDisable() {
|
||||||
|
// Handled by super
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,30 @@
|
|||||||
|
#
|
||||||
|
# Soft Touch EcoEnchant
|
||||||
|
#
|
||||||
|
|
||||||
|
name: "Soft Touch"
|
||||||
|
description: '&a%value%%&r chance to drop a spawner when you mine it.'
|
||||||
|
enabled: true
|
||||||
|
|
||||||
|
obtaining:
|
||||||
|
table: true
|
||||||
|
villager: true
|
||||||
|
loot: true
|
||||||
|
rarity: legendary
|
||||||
|
|
||||||
|
general-config:
|
||||||
|
targets:
|
||||||
|
- pickaxe
|
||||||
|
grindstoneable: true
|
||||||
|
disabled-in-worlds: [ ]
|
||||||
|
conflicts:
|
||||||
|
- silk_touch
|
||||||
|
maximum-level: 5
|
||||||
|
|
||||||
|
config:
|
||||||
|
chance-per-level: 10
|
||||||
|
spawner-name:
|
||||||
|
- "&a%type%&f Spawner"
|
||||||
|
spawner-lore:
|
||||||
|
- "&a%type%&f Spawner"
|
||||||
|
- "&fCan be placed anywhere in the world"
|
@ -0,0 +1,4 @@
|
|||||||
|
name: Soft Touch
|
||||||
|
main: com.willfp.ecoenchants.softtouch.SoftTouchMain
|
||||||
|
version: ${projectVersion}
|
||||||
|
author: Auxilor
|
@ -22,6 +22,7 @@ include ':eco-extensions:intimidation'
|
|||||||
include ':eco-extensions:precision'
|
include ':eco-extensions:precision'
|
||||||
include ':eco-extensions:rainbow'
|
include ':eco-extensions:rainbow'
|
||||||
include ':eco-extensions:sprint-artifacts'
|
include ':eco-extensions:sprint-artifacts'
|
||||||
|
include ':eco-extensions:softtouch'
|
||||||
include ':eco-extensions:summoning'
|
include ':eco-extensions:summoning'
|
||||||
include ':eco-extensions:transmission'
|
include ':eco-extensions:transmission'
|
||||||
include ':eco-extensions:xray'
|
include ':eco-extensions:xray'
|
Loading…
Reference in New Issue
Block a user