fix give and remove items

This commit is contained in:
MeexReay 2025-04-19 23:03:27 +03:00
parent 3ab007cc1e
commit f03714c95c
17 changed files with 62 additions and 35 deletions

0
.gitignore vendored Normal file → Executable file
View File

0
.idea/.gitignore generated vendored Normal file → Executable file
View File

3
.idea/gradle.xml generated Normal file → Executable file
View File

@ -1,5 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="GradleMigrationSettings" migrationVersion="1" />
<component name="GradleSettings">
<option name="linkedExternalProjectsSettings">
<GradleProjectSettings>
@ -7,7 +8,7 @@
<option name="gradleHome" value="" />
<option name="modules">
<set>
<option value="$PROJECT_DIR$" />
<option value="/mnt/work/source/ItemEconomy" />
</set>
</option>
</GradleProjectSettings>

2
.idea/misc.xml generated Normal file → Executable file
View File

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ExternalStorageConfigurationManager" enabled="true" />
<component name="ProjectRootManager" version="2" languageLevel="JDK_21" default="true" project-jdk-name="temurin-21" project-jdk-type="JavaSDK">
<component name="ProjectRootManager" version="2" languageLevel="JDK_17" project-jdk-name="temurin-21" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/out" />
</component>
</project>

0
.idea/uiDesigner.xml generated Normal file → Executable file
View File

2
.idea/vcs.xml generated Normal file → Executable file
View File

@ -1,6 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="$PROJECT_DIR$" vcs="Git" />
<mapping directory="" vcs="Git" />
</component>
</project>

0
LICENSE Normal file → Executable file
View File

0
README.md Normal file → Executable file
View File

2
build.gradle Normal file → Executable file
View File

@ -5,7 +5,7 @@ plugins {
}
group = 'ru.themixray.itemeconomy'
version = '0.1.0'
version = '0.1.1'
spigot {
desc {

0
gradle/wrapper/gradle-wrapper.jar vendored Normal file → Executable file
View File

0
gradle/wrapper/gradle-wrapper.properties vendored Normal file → Executable file
View File

0
gradlew.bat vendored Normal file → Executable file
View File

0
settings.gradle Normal file → Executable file
View File

0
src/main/java/ru/themixray/itemeconomy/Config.java Normal file → Executable file
View File

64
src/main/java/ru/themixray/itemeconomy/Main.java Normal file → Executable file
View File

@ -8,18 +8,33 @@ import org.bukkit.entity.Player;
import org.bukkit.inventory.ItemStack;
import org.bukkit.plugin.ServicePriority;
import org.bukkit.plugin.java.JavaPlugin;
import org.bukkit.scheduler.BukkitRunnable;
import java.io.IOException;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Optional;
import java.util.*;
public class Main extends JavaPlugin {
public static HashMap<String, List<ItemStack>> addItems = new HashMap<>();
@Override
public void onEnable() {
Config.loadConfig(new UnrealConfig(this, getDataFolder(), "config.yml"));
Bukkit.getServicesManager().register(Economy.class, new VaultLayer(), this, ServicePriority.High);
new BukkitRunnable() {
public void run() {
new HashMap<>(addItems).forEach((k, v) -> {
Player player = Bukkit.getPlayerExact(k);
if (player != null) {
for (ItemStack item : v) {
addItems(player, item);
}
addItems.remove(k);
}
});
}
}.runTaskTimer(this, 20, 20);
}
@Override
@ -31,14 +46,43 @@ public class Main extends JavaPlugin {
return Arrays.stream(player.getInventory().getContents()).map(o -> o == null ? new ItemStack(Material.AIR) : o).toList();
}
public static boolean removeItems(Player player, Material type, int amount) {
if(player.getInventory().all(type).values().stream().mapToInt(ItemStack::getAmount).sum()<amount)return false;
player.getInventory().removeItem(new ItemStack(type,amount));
return true;
public static boolean removeItems(String playerName, Material type, int amount) {
System.out.println("try remove item "+type+" "+amount+" from "+playerName);
ItemStack item = new ItemStack(type, amount);
Player player = Bukkit.getPlayerExact(playerName);
if (player == null) {
return false;
} else {
return removeItems(player, item);
}
}
public static void addItems(Player player, Material type, int amount) {
HashMap<Integer, ItemStack> nope=player.getInventory().addItem(new ItemStack(type,amount));
public static void addItems(String playerName, Material type, int amount) {
System.out.println("try add item "+type+" "+amount+" to "+playerName);
ItemStack item = new ItemStack(type, amount);
Player player = Bukkit.getPlayerExact(playerName);
if (player == null) {
List<ItemStack> items = addItems.getOrDefault(playerName, new ArrayList<>());
items.add(item);
addItems.put(playerName, items);
} else {
addItems(player, item);
}
}
private static boolean removeItems(Player player, ItemStack item) {
System.out.println("remove item "+item.getType()+" "+item.getAmount()+" from "+player.getName());
if (player.getInventory().all(item.getType()).values().stream().mapToInt(ItemStack::getAmount).sum() < item.getAmount()) return false;
return player.getInventory().removeItem(item).isEmpty();
}
private static void addItems(Player player, ItemStack item) {
System.out.println("add item "+item.getType()+" "+item.getAmount()+" from "+player.getName());
HashMap<Integer, ItemStack> nope = player.getInventory().addItem(item);
for (ItemStack v:nope.values()) player.getWorld().dropItemNaturally(player.getLocation(), v);
}
}

22
src/main/java/ru/themixray/itemeconomy/VaultLayer.java Normal file → Executable file
View File

@ -83,16 +83,7 @@ public class VaultLayer implements Economy {
EconomyResponse.ResponseType.FAILURE,
"Недостаточно средств");
Player player;
if ((player = Bukkit.getPlayer(playerName)) == null) {
return new EconomyResponse(
amount,
getBalance(playerName),
EconomyResponse.ResponseType.FAILURE,
"Игрок офлайн");
}
if (!Main.removeItems(player, Config.ITEM, (int) amount)) {
if (!Main.removeItems(playerName, Config.ITEM, (int) Math.ceil(amount))) {
return new EconomyResponse(
amount,
getBalance(playerName),
@ -112,16 +103,7 @@ public class VaultLayer implements Economy {
if (amount == 0) return new EconomyResponse(amount,getBalance(playerName),EconomyResponse.ResponseType.SUCCESS,null);
if (amount < 0) return withdrawPlayer(playerName,-amount);
Player player;
if ((player = Bukkit.getPlayer(playerName)) == null) {
return new EconomyResponse(
amount,
getBalance(playerName),
EconomyResponse.ResponseType.FAILURE,
"Игрок офлайн");
}
Main.addItems(player, Config.ITEM, (int) amount);
Main.addItems(playerName, Config.ITEM, (int) amount);
return new EconomyResponse(
amount,

0
src/main/resources/config.yml Normal file → Executable file
View File