diff --git a/pom.xml b/pom.xml
index af332f4..b3dd4b0 100644
--- a/pom.xml
+++ b/pom.xml
@@ -6,7 +6,7 @@
com.artillexstudios
AxRankMenu
- 1.1.0
+ 1.0.3
jar
AxRankMenu
@@ -100,6 +100,10 @@
placeholderapi
https://repo.extendedclip.com/content/repositories/placeholderapi/
+
+ techscode
+ https://repo.techscode.com/repository/maven-releases/
+
@@ -112,7 +116,7 @@
com.artillexstudios.axapi
axapi
- 1.4.6
+ 1.4.10
compile
@@ -194,5 +198,11 @@
2.11.3
provided
+
+ me.TechsCode
+ UltraEconomyAPI
+ 2.6.4
+ provided
+
diff --git a/src/main/java/com/artillexstudios/axrankmenu/hooks/HookManager.java b/src/main/java/com/artillexstudios/axrankmenu/hooks/HookManager.java
index 95d640b..d411dcb 100644
--- a/src/main/java/com/artillexstudios/axrankmenu/hooks/HookManager.java
+++ b/src/main/java/com/artillexstudios/axrankmenu/hooks/HookManager.java
@@ -5,6 +5,7 @@
import com.artillexstudios.axrankmenu.hooks.currency.CurrencyHook;
import com.artillexstudios.axrankmenu.hooks.currency.PlayerPointsHook;
import com.artillexstudios.axrankmenu.hooks.currency.RoyaleEconomyHook;
+import com.artillexstudios.axrankmenu.hooks.currency.UltraEconomyHook;
import com.artillexstudios.axrankmenu.hooks.currency.VaultHook;
import org.bukkit.Bukkit;
import org.bukkit.plugin.Plugin;
@@ -40,13 +41,20 @@ public void updateHooks() {
} else {
Bukkit.getConsoleSender().sendMessage(StringUtils.formatToString("FF3333[AxRankMenu] CoinsEngine is set in config.yml, but it isn't installed, please download it or change it in the config to stop errors!"));
}
-
+
if (CONFIG.getBoolean("hooks.RoyaleEconomy.register", true) && Bukkit.getPluginManager().getPlugin("RoyaleEconomy") != null) {
currency.add(new RoyaleEconomyHook());
Bukkit.getConsoleSender().sendMessage(StringUtils.formatToString("!FF33[AxRankMenu] Hooked into RoyaleEconomy!"));
} else {
Bukkit.getConsoleSender().sendMessage(StringUtils.formatToString("FF3333[AxRankMenu] RoyaleEconomy is set in config.yml, but it isn't installed, please download it or change it in the config to stop errors!"));
}
+
+ if (CONFIG.getBoolean("hooks.UltraEconomy.register", true) && Bukkit.getPluginManager().getPlugin("UltraEconomy") != null) {
+ currency.add(new UltraEconomyHook());
+ Bukkit.getConsoleSender().sendMessage(StringUtils.formatToString("!FF33[AxRankMenu] Hooked into UltraEconomy!"));
+ } else {
+ Bukkit.getConsoleSender().sendMessage(StringUtils.formatToString("FF3333[AxRankMenu] UltraEconomy is set in config.yml, but it isn't installed, please download it or change it in the config to stop errors!"));
+ }
for (CurrencyHook hook : currency) hook.setup();
diff --git a/src/main/java/com/artillexstudios/axrankmenu/hooks/currency/UltraEconomyHook.java b/src/main/java/com/artillexstudios/axrankmenu/hooks/currency/UltraEconomyHook.java
new file mode 100644
index 0000000..092c596
--- /dev/null
+++ b/src/main/java/com/artillexstudios/axrankmenu/hooks/currency/UltraEconomyHook.java
@@ -0,0 +1,48 @@
+package com.artillexstudios.axrankmenu.hooks.currency;
+
+import me.TechsCode.UltraEconomy.UltraEconomy;
+import me.TechsCode.UltraEconomy.objects.Account;
+import me.TechsCode.UltraEconomy.objects.Currency;
+import org.bukkit.entity.Player;
+import org.jetbrains.annotations.NotNull;
+
+import java.util.Optional;
+
+import static com.artillexstudios.axrankmenu.AxRankMenu.CONFIG;
+
+public class UltraEconomyHook implements CurrencyHook {
+ private Currency currency = null;
+
+ @Override
+ public void setup() {
+ final Optional currencyOptional = UltraEconomy.getAPI().getCurrencies().name(CONFIG.getString("hook-settings.UltraEconomy.currency-name", "coins"));
+ if (!currencyOptional.isPresent()) throw new RuntimeException("Currency not found!");
+ currency = currencyOptional.get();
+ }
+
+ @Override
+ public String getName() {
+ return "UltraEconomy";
+ }
+
+ @Override
+ public double getBalance(@NotNull Player p) {
+ final Optional account = UltraEconomy.getAPI().getAccounts().uuid(p.getUniqueId());
+ if (!account.isPresent()) return 0.0D;
+ return account.get().getBalance(currency).getOnHand();
+ }
+
+ @Override
+ public void giveBalance(@NotNull Player p, double amount) {
+ final Optional account = UltraEconomy.getAPI().getAccounts().uuid(p.getUniqueId());
+ if (!account.isPresent()) return;
+ account.get().addBalance(currency, amount);
+ }
+
+ @Override
+ public void takeBalance(@NotNull Player p, double amount) {
+ final Optional account = UltraEconomy.getAPI().getAccounts().uuid(p.getUniqueId());
+ if (!account.isPresent()) return;
+ account.get().removeBalance(currency, amount);
+ }
+}
\ No newline at end of file
diff --git a/src/main/java/com/artillexstudios/axrankmenu/utils/PlaceholderUtils.java b/src/main/java/com/artillexstudios/axrankmenu/utils/PlaceholderUtils.java
index 0168119..3495129 100644
--- a/src/main/java/com/artillexstudios/axrankmenu/utils/PlaceholderUtils.java
+++ b/src/main/java/com/artillexstudios/axrankmenu/utils/PlaceholderUtils.java
@@ -14,8 +14,8 @@ public class PlaceholderUtils {
public static String parsePlaceholders(@NotNull String string, @NotNull Section section) {
string = string.replace("%price%", StringUtils.formatNumber("#,###.##", section.getDouble("price")));
- LuckPerms lpApi = LuckPermsProvider.get();
- ImmutableContextSet set = lpApi.getContextManager().getStaticContext();
+ final LuckPerms lpApi = LuckPermsProvider.get();
+ final ImmutableContextSet set = lpApi.getContextManager().getStaticContext();
string = string.replace("%server%", (section.getString("server").equals("") && set.getAnyValue("server").isPresent()) ? set.getAnyValue("server").get() : section.getString("server"));
if (HookManager.getPapi() != null)
diff --git a/src/main/resources/config.yml b/src/main/resources/config.yml
index 8ca8e66..9a92d20 100644
--- a/src/main/resources/config.yml
+++ b/src/main/resources/config.yml
@@ -66,6 +66,9 @@ hooks:
CoinsEngine:
register: true
currency-name: "coins"
+ UltraEconomy:
+ register: true
+ currency-name: "coins"
PlaceholderAPI:
register: true
diff --git a/src/main/resources/plugin.yml b/src/main/resources/plugin.yml
index 6ddc39d..a1bbb9d 100644
--- a/src/main/resources/plugin.yml
+++ b/src/main/resources/plugin.yml
@@ -7,6 +7,13 @@ folia-supported: true
depend:
- LuckPerms
+softdepend:
+ - PlaceholderAPI
+ - CoinsEngine
+ - PlayerPoints
+ - RoyaleEconomy
+ - UltraEconomy
+
commands:
axrankmenu:
usage: /